Net Core 自定义 Middleware 加密解密
程序员文章站
2022-07-02 13:03:08
前言:第一次写文章,有问题请轻喷 当前使用 Net Core 版本 2.1.3 我们经常在开发中需要把实体的主键 Id 传输到前端,但是在Get的时候又不想让前端能看到明文,我们通常会加密这些数据,所以有了这篇文章来写一些心得。(主要是我在网上找的代码写得太简单了,不符合我的需求) 这里我用的是 N ......
前言:第一次写文章,有问题请轻喷
当前使用 net core 版本 2.1.3
我们经常在开发中需要把实体的主键 id 传输到前端,但是在get的时候又不想让前端能看到明文,我们通常会加密这些数据,所以有了这篇文章来写一些心得。(主要是我在网上找的代码写得太简单了,不符合我的需求)
这里我用的是 net core 自带的 dataprotector ,使用方式自行百度一下
关于中间件 middleware 可以看看博园大佬写的,太多就不列举了,官方文档:
一张图来概括就是这样:
第一步,过滤请求(request):
要注意这里 newresponse 是没有 dispose 的,本来是用的双重 using ,但是感觉嵌套太多,个人编码风格,可以自行选择
目前只做了 get 和 post 其他 method 可自行添加。目前只是匹配参数中,字段名以 id 结尾的字段进行筛选,可以自己做扩展,自定义特性和反射去做也是可以的,更加灵活,
不过要牺牲一点点性能,看你怎么取舍了和你的需求了,这里只是做一次demo。
因为 response 都是一样过滤,所以比较简单。
整体执行流程图
写在最后:整个项目就不发上去了,帮朋友写的一个小玩意,这个类文件我发布到百度网盘把。
链接: https://pan.baidu.com/s/1m72thkw8zazyypwo0yw2fq 提取码: r3qh
推荐阅读
-
ASP.NET Core Web 应用程序开发期间部署到IIS自定义主机域名并附加到进程调试
-
.NET Core开发日志——Middleware
-
利用Asp.Net Core的MiddleWare思想如何处理复杂业务流程详解
-
在ASP.NET Core中显示自定义的错误页面
-
php自定义加密与解密程序实例
-
ASP.NET CORE 学习之自定义异常处理
-
asp.net TripleDES加密、解密算法
-
ASP.NET中DES加密与解密MD5加密帮助类的实现代码
-
ASP.NET Core使用Middleware设置有条件允许访问路由
-
asp.net Core 中AuthorizationHandler 实现自定义授权