当前位置: 首页 > news >正文

网站建设网页设计案例点评网站模板

网站建设网页设计案例,点评网站模板,php做网站技术方案,建设企业银行网站前言 先给大家看下效果#xff0c;原本我们的请求是这样子的 加密后的数据传输是这样子的 加解密步骤#xff1a; 1.前端请求前进行加密#xff0c;然后发送到后端 2.后端收到请求后解密 3.后端返回数据前进行加密 4.前端拿到加密串后#xff0c;解密数据 加解密算法原本我们的请求是这样子的 加密后的数据传输是这样子的 加解密步骤 1.前端请求前进行加密然后发送到后端 2.后端收到请求后解密 3.后端返回数据前进行加密 4.前端拿到加密串后解密数据 加解密算法 本文用的是国密算法作为参考当然大家也可以用其它算法进行加解密 国密算法加解密可参照java/vue使用国密sm2进行数据加密_vue sm2_qq243920161的博客-CSDN博客java/vue使用国密sm2https://blog.csdn.net/qq243920161/article/details/127865091 一、前端请求前进行加密然后发送到后端 import axios from axios; import { sm2 } from sm-crypto;axios.interceptors.request.use(config {// form-data传参方式不加密if (config.headers[Content-Type] application/x-www-form-urlencoded) {return;}// 非body方式传参不加密if (config.data) {return;}// 使用国密算法进行加密let encryptData sm2.doEncrypt(JSON.stringify(config.data), 加密公钥请提前生成好);config.data {data: encryptData} }); 以上代码使用了axios拦截器对所有请求进行拦截拦截器里使用config.data获取到请求的body进行加密加密后把加密后的数据重新赋值到config.datasm-crypto是国密算法的依赖使用前npm install sm-crypto即可 请确保config.data是一个对象或者数组不要是一个字符串否则后端获取body时会失败 加密成功后从network就能看到加密的数据了 二、后端收到请求后解密 这里有两个类直接复制粘贴即可一个是RequestWrapper这个类是用来读取body的一个是BodyRequestWrapper这个类是用来解密后将解密后的数据封装到request供Controller层使用这里直接上代码了 import javax.servlet.ReadListener; import javax.servlet.ServletInputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequestWrapper; import java.io.*;/*** 用来读取body*/ public class RequestWrapper extends HttpServletRequestWrapper {private final String body;public RequestWrapper(HttpServletRequest request) {super(request);StringBuilder stringBuilder new StringBuilder();BufferedReader bufferedReader null;InputStream inputStream null;try {inputStream request.getInputStream();if (inputStream ! null) {bufferedReader new BufferedReader(new InputStreamReader(inputStream));char[] charBuffer new char[128];int bytesRead -1;while ((bytesRead bufferedReader.read(charBuffer)) 0) {stringBuilder.append(charBuffer, 0, bytesRead);}} else {stringBuilder.append();}} catch (IOException ex) {} finally {if (inputStream ! null) {try {inputStream.close();} catch (IOException e) {e.printStackTrace();}}if (bufferedReader ! null) {try {bufferedReader.close();} catch (IOException e) {e.printStackTrace();}}}body stringBuilder.toString();}Overridepublic ServletInputStream getInputStream() throws IOException {final ByteArrayInputStream byteArrayInputStream new ByteArrayInputStream(body.getBytes());ServletInputStream servletInputStream new ServletInputStream() {Overridepublic boolean isFinished() {return false;}Overridepublic boolean isReady() {return false;}Overridepublic void setReadListener(ReadListener readListener) {}Overridepublic int read() throws IOException {return byteArrayInputStream.read();}};return servletInputStream;}Overridepublic BufferedReader getReader() throws IOException {return new BufferedReader(new InputStreamReader(this.getInputStream()));}public String getBody() {return this.body;} }import javax.servlet.ReadListener; import javax.servlet.ServletInputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequestWrapper; import java.io.BufferedReader; import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStreamReader;/*** 用来重新封装request*/ public class BodyRequestWrapper extends HttpServletRequestWrapper {/*** 存放JSON数据主体*/private String body;public BodyRequestWrapper(HttpServletRequest request, String context) {super(request);body context;}Overridepublic ServletInputStream getInputStream() throws IOException {final ByteArrayInputStream byteArrayInputStream new ByteArrayInputStream(body.getBytes(UTF-8));return new ServletInputStream() {Overridepublic int read() throws IOException {return byteArrayInputStream.read();}Overridepublic boolean isFinished() {return false;}Overridepublic boolean isReady() {return false;}Overridepublic void setReadListener(ReadListener listener) {}};}Overridepublic BufferedReader getReader() throws IOException {return new BufferedReader(new InputStreamReader(this.getInputStream()));} } 然后我们需要写一个请求过滤器继承Filter对所有请求接口进行过滤 import com.alibaba.fastjson2.JSON; import org.springframework.stereotype.Component; import org.springframework.util.StringUtils;import javax.annotation.Resource; import javax.servlet.*; import javax.servlet.http.HttpServletRequest; import java.io.IOException;/*** 请求加解密过滤器** author 猴哥*/ Component public class RequestHandler implements Filter {/*** 进行请求加密*/Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {// form-data不校验if (application/x-www-form-urlencoded.equals(request.getContentType())) {chain.doFilter(request, response);return;}// 拿到加密串String data new RequestWrapper((HttpServletRequest) request).getBody();if (StringUtils.isEmpty(data)) {chain.doFilter(request, response);return;}// 解析String body Sm2Util.decrypt(解密私钥, data);request new BodyRequestWrapper((HttpServletRequest) request, body);chain.doFilter(request, response);} }Sm2Util是国密的解密方式工具类在之前分享的帖子里有当然大家可以用自己喜欢的方式进行加解密 java/vue使用国密sm2进行数据加密_vue sm2_qq243920161的博客-CSDN博客java/vue使用国密sm2https://blog.csdn.net/qq243920161/article/details/127865091 这样就能拿到加密串了 但是有个问题就是这样写的话所有请求都会走Filter但是我们只想让部分请求走Filter怎么办呢写一个配置类就可以了这样就可以将url进行过滤 import org.springframework.boot.web.servlet.FilterRegistrationBean; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;/*** author 猴哥*/ Configuration public class EncryptionConfiguration {/*** 过滤器配置*/Beanpublic FilterRegistrationBeanRequestHandler filterRegistration(RequestHandler requestHandler) {FilterRegistrationBeanRequestHandler registration new FilterRegistrationBean();registration.setFilter(requestHandler);registration.addUrlPatterns(/plugin/*);registration.setName(encryptionFilter);//设置优先级别registration.setOrder(1);return registration;} }以上代码就是将/plugin开头的url进行拦截代码不难就不用过多解释了吧 三、后端返回数据前进行加密 代码如下 import com.alibaba.fastjson.JSON; import org.springframework.core.MethodParameter; import org.springframework.http.MediaType; import org.springframework.http.converter.HttpMessageConverter; import org.springframework.http.server.ServerHttpRequest; import org.springframework.http.server.ServerHttpResponse; import org.springframework.stereotype.Component; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.servlet.mvc.method.annotation.ResponseBodyAdvice;import javax.annotation.Resource; import java.util.ArrayList; import java.util.List;/*** 响应加解密拦截器** author 猴哥*/ Component ControllerAdvice public class ResponseHandler implements ResponseBodyAdviceObject {/*** 返回true才会走beforeBodyWrite方法*/Overridepublic boolean supports(MethodParameter methodParameter, Class? extends HttpMessageConverter? aClass) {return true;}/*** 响应加密*/Overridepublic Object beforeBodyWrite(Object body, MethodParameter methodParameter, MediaType mediaType, Class? extends HttpMessageConverter? aClass, ServerHttpRequest request, ServerHttpResponse serverHttpResponse) {// 拿到响应的数据String json JSON.toJSONString(body);// 进行加密return Sm2Util.encrypt(加密公钥, json);} }前端即可拿到这样一个加密数据 四、前端拿到加密串后解密数据 需要再axios中添加一个响应拦截器代码如下 import axios from axios; import { sm2 } from sm-crypto;// 响应拦截器 axios.interceptors.response.use(res {res.data JSON.parse(sm2.doDecrypt(res.data, 解密私钥));console.log(解密出来的数据, res.data); }); 打印如图所示
http://www.hkea.cn/news/14530177/

相关文章:

  • 服装企业网站模板工业设计网站外网
  • 钦州建站哪家好沪浙网站
  • 做遗嘱的网站有哪些郑州网站建设开发
  • 做网站一般把宽度做多少二级域名能查到一级域名吗
  • 装修公司网站模板下载武城网站建设
  • 如何制作网站板块客户评价 网站建设
  • 前端开发常用网站app定制开发制作
  • 深圳微信网站公司网站维护基础知识
  • 信阳网站建设信阳图片链接生成器在线
  • 浙江省建设网站徐叨法长春网站建设 信赖吉网传媒
  • 设计师工作室网站深圳龙华区防控措施
  • 怎么打开网站云梦县网站开发
  • 做跨境电商网站的意义哪个公司的网站做的好
  • 上海专业网站建设 公司网站建设有什么出路
  • 服务类网站模板wamp 安装wordpress
  • 网站开发的硬件设备百度广州分公司销售岗位怎么样
  • 网站收录后然后怎么做站长工具手机综合查询
  • 网站流程表广州安全教育平台登录入囗
  • 深圳找工作的网站wordpress+仿简书模板
  • 网站设计电脑培训学校手表欧米茄官网
  • 九江浔阳网站建设凉山建设网站
  • 西部数码网站管理助手3.0教程id如何打开wordpress
  • 阿里云 多域名解析 到不同的网站东莞市建设网站培训
  • 宜昌市做网站的公司lollipop Wordpress
  • 东莞h5网站建设wordpress要多少钱
  • 标志空间 网站广州天河区核酸检测点
  • 中国工程建设网站湘潭网站建设搭建
  • 十大免费行情软件下载网站用easyui 做的网站
  • 做站用什么网站程序广州优化网站排名
  • 阿里云上怎么做网页网站有没有免费手游代理