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

做网站建设公司企业六安网约车收入怎么样

做网站建设公司企业,六安网约车收入怎么样,网站收录查询临沂seo,asp网站上一篇下一篇代码前言 先给大家看下效果#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/14393917/

相关文章:

  • 国际知名的论文网站班级同学录网站建设
  • 网络建站技术设计一个网站需要什么
  • 网站里的聊天怎么做的wordpress 维护代码
  • 什么后台做网站安全做京东网站需要哪些手续费
  • 江苏建设工程招标网官方网站广告公司注册
  • 国外网站布局python wordpress采集器
  • 男生做网站编辑上海人才服务网官网
  • 长春网站改版品牌网站建设服务
  • 网站建设与制作培训通知建设工程合同模板
  • 重庆网站建设咨询网站包装推广案例
  • 建设银行E路航如何自动进入网站怎样对一个网站做seo
  • 中国电子商务网站建设供别人采集的网站怎么做
  • 网站开发项目流程设计网站开发的教学视频
  • 最大的地方门户网站源码肇庆免费模板建站
  • 做基础工程分包应上什么网站网站设计公司合肥
  • 网站开发的原理永久免费无代码开发平台下载
  • wordpress主题 资源站阿里云官方网
  • 杭州网站的建设北京网站建设飞沐
  • 做网站三河360建设网站免费
  • 网站建设中最重要的是什么玄圭互联网站建设推广
  • 宁夏建设投资集团公司网站147seo工具
  • 网站建立多少钱企业宣传片制作哪家好
  • 外网网站有什么好的推荐网站标题怎么做链接
  • 宁波网站建设信任蓉胜网络好华天动力oa系统
  • 网站图片特效源码纷享销客crm官网
  • 织梦网站被植入广告wordpress怎么开发
  • 电子商务网站建设项目的阶段下列( )是计算机网页制作工具
  • 湖南地税局官网站水利建设基金管理咨询公司取名
  • 高特效网站广州个人网站备案要多久
  • 网站建设教学改进c 企业网站开发