也想出现在这里? 联系我们

Java防止SQL注入的几个途径

作者 : 小编 本文共1929个字,预计阅读时间需要5分钟 发布时间: 2021-06-9 共1.49K人阅读
也想出现在这里? 联系我们

java防SQL注入,最简单的办法是杜绝SQL拼接,SQL注入攻击能得逞是因为在原有SQL语句中加入了新的逻辑,如果使用PreparedStatement来代替Statement来执行SQL语句,其后只是输入参数,SQL注入攻击手段将无效,这是因为PreparedStatement不允许在不同的插入时间改变查询的逻辑结构 ,大部分的SQL注入已经挡住了, 在WEB层我们可以过滤用户的输入来防止SQL注入比如用Filter来过滤全局的表单参数01 import java.io.IOException;02 import java.util.Iterator;03 import javax.servlet.Filter;04 import javax.servlet.FilterChain;05 import javax.servlet.FilterConfig;06 import javax.servlet.ServletException;07 import javax.servlet.ServletRequest;08 import javax.servlet.ServletResponse;09 import javax.servlet.http.HttpServletRequest;10 import javax.servlet.http.HttpServletResponse;11 /**12 * 通过Filter过滤器来防SQL注入攻击13 *

14 */15 public class SQLFilter implements Filter {16 private String inj_str = "\’|and|exec|insert|select|delete|update|count|*|%|chr|mid|master|truncate|char|declare|; |or|-|+|,";17 protected FilterConfig filterConfig = null;18 /**19 * Should a character encoding specified by the client be ignored?20 */21 protected boolean ignore = true;22 public void init(FilterConfig config) throws ServletException {23 this.filterConfig = config;24 this.inj_str = filterConfig.getInitParameter("keywords");25 }26 public void doFilter(ServletRequest request, ServletResponse response,27 FilterChain chain) throws IOException, ServletException {28 HttpServletRequest req = (HttpServletRequest)request;29 HttpServletResponse res = (HttpServletResponse)response;30 Iterator values = req.getParameterMap().values().iterator();//获取所有的表单参数31 while(values.hasNext()){32 String[] value = (String[])values.next();33 for(int i = 0;i < value.length;i++){34 if(sql_inj(value[i])){35 //TODO这里发现sql注入代码的业务逻辑代码36 return;37 }38 }39 }40 chain.doFilter(request, response);41 }42 public boolean sql_inj(String str)43 {44 String[] inj_stra=inj_str.split("\\\\|");45 for (int i=0 ; i < inj_stra.length ; i++ )46 {47 if (str.indexOf(" "+inj_stra[i]+" ")>=0)48 {49 return true;50 }51 }52 return false;53 }54 }也可以单独在需要防范SQL注入的JavaBean的字段上过滤:1 /**2 * 防止sql注入3 *4 * @param sql5 * @return6 */7 public static String TransactSQLInjection(String sql) {8 return sql.replaceAll(".*([\’;]+|(–)+).*", " ");9 }

1. 本站所提供的源码模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: rayer@88.com),我们会及时删除,给您带来的不便,我们深表歉意!
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » Java防止SQL注入的几个途径

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
织梦模板使用说明
你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html

发表评论

Copyright 2015-2020 版权所有 资源分享吧 Rights Reserved. 蜀ICP备14022927号-1
开通VIP 享更多特权,建议使用QQ登录