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

电子商城网站开发项目描述seo是做网站源码还是什么

电子商城网站开发项目描述,seo是做网站源码还是什么,wordpress writr,中山做网站的问题背景 在项目开发过程中#xff0c;基本都会有列表条件查询#xff0c;例如用户管理会有通过用户姓名模糊查询用户#xff0c;课程管理会有课程名称模糊查询课程等等。 而查询过程中如果用户在界面上输入一些特殊字符#xff0c;例如#xff1a;%_等等#xff0c;这…问题背景 在项目开发过程中基本都会有列表条件查询例如用户管理会有通过用户姓名模糊查询用户课程管理会有课程名称模糊查询课程等等。 而查询过程中如果用户在界面上输入一些特殊字符例如%_等等这时可以发现最终生成的SQL大致如下 select * from t_user where name like %%% select * from t_user where name like %_% 这样就会导致将用户表的所有数据都查询出来这显然不是用户想看到的结果用户的本意只是想找名字叫%的人而由于这些字符因为在数据库Mysql等中有着特殊含义 %表示任意字符_表示任意一个字符所有导致了这样的结果。 如何解决 很容易想到的解决方案就是在生成SQL的时候对这些个字符进行转义让数据库将这些字符当作普通的字符串来处理而不是字符通配符。 例如如果是使用mybatisplus可以这样写 LambdaQueryWrapperUser queryWrapper Wrappers.lambdaQuery(User.class)//使用对用户姓名里面的%_\进行替换.like(StringUtils.isNotBlank(qo.getName()), User::getName, replaceStr(qo.getName()));private String replaceStr(String str) {if (str ! null !.equals(str)) {str str.replaceAll(\\\\, \\\\\\\\).replace(_, \\_).replace(\, \\).replace(%, \\%).replace(*, \\*);}return str;} 这样如果输入的name%最终生成的SQL如下 select * from t_user where name like %\%% 这里的\%就会当作普通的字符串进行条件匹配如果有name里面含有%就会被查询出来满足了用户的期望。 但是一个系统中这样的条件查询肯定不止一个会有几十、几百个每一个都这样处理会显得很麻烦那有什么办法可以统一处理吗 当然是有的咱们不是有AOP嘛对所有分页查询的入参做个拦截对这些个特殊字符进行处理然后再去调用接口就可以了可以这样处理 /*** 统一处理列表分页条件查询的入参的特殊字符* 再Mysql查询中有%_\三个特殊字符* %代表通配符任意字符* _: 代表任意一个字符* \: 在Java代码中需要四个\\\\才能查出数据库中一个\***/ Component Aspect public class QueryRequestAspect {/*** 定义切面根据自己的情况定义* 所有controller下面所有page开头的接口*/Pointcut(value execution(* com.xxx.xxx.controller..*.page*(..)))private void queryPointCut() {}//可以使用Before类型的通知、也可以使用Around类型通知SneakyThrowsBefore(value queryPointCut())public void process(JoinPoint joinPoint) {Object[] args joinPoint.getArgs();if (args ! null args.length ! 0) {//对入参进行处理for (int i 0; i args.length; i) {Field[] declaredFields args[i].getClass().getDeclaredFields();for (Field declaredField : declaredFields) {declaredField.setAccessible(true);Object o declaredField.get(args[i]);if (o instanceof String) {declaredField.set(args[i], replaceStr((String) o));}}}}}private String replaceStr(String str) {if (str ! null !.equals(str)) {str str.replaceAll(\\\\, \\\\\\\\).replace(_, \\_).replace(\, \\).replace(%, \\%).replace(*, \\*);}return str;}} 这样通过这个QueryRequestAspect 切面就可以统一处理分页查询的条件入参了。 参考资料 Java查询Mysql数据库时查询条件带特殊字符\ % ‘ * _的处理方式_查询数据库字段包含某特殊字符_weixin_43828846的博客-CSDN博客 SpringBoot AOP拦截、修改请求参数_aop 修改参数值_HouXinLin_CSDN的博客-CSDN博客
http://www.w-s-a.com/news/272133/

相关文章:

  • 做网站创意杭州家具网站建设方案
  • 福州seo网站推广优化乐清建网站
  • 莆田cms建站模板简述网站设计流程
  • 班级网站建设组织机构建设注册中心网站首页
  • 即墨网站建设地址怎么在文档中做网站一点就开
  • 做网站联系方式互联网行业分析
  • 杭州网站建设索q479185700高淳网站建设
  • 有什么做任务拿钱的网站精准的搜索引擎优化
  • 洛阳有建社网站的吗电力建设工程质量监督总网站
  • 网站404报错热水器网站建设 中企动力
  • 网站降权恢复淘宝 网站建设
  • 安州区建设局网站台州优秀关键词优化
  • 网站假设教程湖南微信管理系统
  • 网站备案属于公司哪一块哪个网站是专门做封面素材
  • 广州个人做网站内江建设局网站
  • 网站开发 360百科大连哪里有手机自适应网站建设维护
  • 如何查网站pv网站功防教程
  • 建设银行网站信息补充营销推广的作用
  • 网站见建设seo外链自动群发工具
  • 在境外做网站网站团购网站seo
  • 进网站后台加什么360推广 网站建设
  • 网站备案号码专做网站漏扫的工具
  • 罗店网站建设wordpress响应式
  • 网站怎么制作小程序wordpress实时获取qq资料
  • 网站的流量怎么赚钱经销做网站都有什么好处
  • 如何做好网站首页企术建站
  • 杭州网站建设咨询蓝韵网络聊城有制作网站的吗
  • 网站开发注意的事项深圳企业网站
  • 哈尔滨网站制作哪里专业网站建设维护有哪些内容
  • 花的网站建设规划书网络营销培训