首页 > 其他分享 >[转]SSH框架 Struts2 过滤特殊字符,防止xss攻击

[转]SSH框架 Struts2 过滤特殊字符,防止xss攻击

时间:2023-11-17 16:33:23浏览次数:32  
标签:xss return String value Struts2 SSH import null public

原文地址:基于Struts2修复XSS漏洞(博主验证有效)_struts2 xss-CSDN博客

1.编写XssFilter

import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import com.itcast.utils.XssHttpServletRequestWrapper;

/**
* XSS防跨站脚本攻击过滤器
*
*/
public class XssFilter implements Filter {
FilterConfig filterConfig = null;
/**
* Default constructor.
*/
public XssFilter() {
}

public void destroy() {
this.filterConfig = null;
}

public void init(FilterConfig fConfig) throws ServletException {
this.filterConfig = fConfig;
}

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
chain.doFilter(new XssHttpServletRequestWrapper((HttpServletRequest) request), response);
}


}

 

2.编写XssHttpServletRequestWrapper类

import java.util.Enumeration;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import org.apache.struts2.dispatcher.StrutsRequestWrapper;
import org.springframework.util.CollectionUtils;
public class XssHttpServletRequestWrapper extends StrutsRequestWrapper {

HttpServletRequest orgRequest = null;

public XssHttpServletRequestWrapper(HttpServletRequest servletRequest) {
super(servletRequest);
orgRequest = servletRequest;
}

/**
* 重写getParameterValues方法
* 通过循环取出每一个请求结果
* 再对请求结果进行过滤
* */
public String[] getParameterValues(String parameter) {
String[] values = super.getParameterValues(parameter);
if (values == null) {
return null;
}
int count = values.length;
String[] encodedValues = new String[count];
for (int i = 0; i < count; i++) {
encodedValues[i] = cleanXSS(values[i]);
}
return encodedValues;
}

/**
* 重写getParameter方法
* 对请求结果进行过滤
* */
public String getParameter(String parameter) {
String value = super.getParameter(parameter);
if (value == null) {
return null;
}
return cleanXSS(value);
}

public String getHeader(String name) {
String value = super.getHeader(name);
if (value == null)
return null;
return cleanXSS(value);
}
/**
* 获取最原始的request
*
* @return
*/
public HttpServletRequest getOrgRequest() {
return orgRequest;
}

/**
* 获取最原始的request的静态方法
*
* @return
*/
public static HttpServletRequest getOrgRequest(HttpServletRequest req) {
if (req instanceof XssHttpServletRequestWrapper) {
return ((XssHttpServletRequestWrapper) req).getOrgRequest();
}
return req;
}

@Override
public Enumeration<String> getParameterNames() {
Enumeration<String> names = super.getParameterNames();
while(names.hasMoreElements()){
String name = names.nextElement();
name = cleanXSS(name);
}
return names;
}


@Override
public Map getParameterMap() {

Map paramMap = super.getParameterMap();
if (CollectionUtils.isEmpty(paramMap)) {
return paramMap;
}

for (Object value : paramMap.values()) {
String[] str = (String[])value;
if (str != null) {
for (int i = 0; i < str.length; i++) {

str[i] = cleanXSS(str[i]);
}
}
}
return paramMap;
}

private String cleanXSS(String value) {
value = value.replaceAll("<", "& lt;").replaceAll(">", "& gt;");
//先暂时去除 英文括号的拦截
// value = value.replaceAll("\\(", "& #40;").replaceAll("\\)", "& #41;");
value = value.replaceAll("'", "& #39;");
value = value.replaceAll("eval\\((.*)\\)", "");
value = value.replaceAll("[\\\"\\\'][\\s]*javascript:(.*)[\\\"\\\']","\"\"");
value = value.replaceAll("script", "");
value = value.replaceAll("alert", "");

return value;
}
}

 

3.注解配置web.xml 过滤器XssFilter

注意:struts-xssFilter一定要在StrutsPrepareAndExecuteFilter之前执行否则无效,具体体现在struts-xssFilter自定义过滤器在StrutsPrepareAndExecuteFilter注解之上。

<filter>
<filter-name>struts-xssFilter</filter-name>
<filter-class>
com.itcast.filter.XssFilter
</filter-class>
</filter>

<filter-mapping>
<filter-name>struts-xssFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter
</filter-class>
</filter>

<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
4.效果演示

输入富文本

 

后端接收过滤后文本(特殊字符经过转译)

 


————————————————
版权声明:本文为CSDN博主「古大狼」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_42210904/article/details/107490611

标签:xss,return,String,value,Struts2,SSH,import,null,public
From: https://www.cnblogs.com/dirgo/p/17839091.html

相关文章

  • windows 配置 SSH 连接 GitLab,实现免密登录
    第一步,生成秘钥并配置到GitLab上(一路回车),这里的邮箱是注册邮箱ssh-keygen-trsa-C"your_email@youremail.com"第二步,这时会在上面的目录生成很多文件,我们只需要id_rsa.pub文件,使用记事本复制里面的内容 第三步,在 GitLab的偏好设置里面找到SSH密钥,将id_rsa.pub......
  • 通过无线SSH连接树莓派系统
    在树莓派开发的大多数情况下,没有显示屏和外接键鼠,此时就需要通过一些其他的方法来连接并操控树莓派系统配置无线路由器查看无线路由器机身上的使用说明在电脑上访问路由器的管理员页面设置允许路由器下连接的各设备互相访问安装树莓派系统:使用imager安装树莓派系统,因......
  • 如何用SSH密钥实现加密和电子签名?
    SSH(SecureShell)密钥对可用于实现加密和数字签名,以确保数据的机密性和完整性。以下是使用SSH密钥进行加密和数字签名的基本步骤:1.生成SSH密钥对:在本地计算机上生成SSH密钥对,这包括私钥和公钥。使用以下命令生成:ssh-keygen-trsa-b2048这将生成一个2048位的RSA密钥对。您将被提......
  • 什么是xss攻击
    1.概念XSS攻击指的是跨站脚本攻击,是一种代码注入攻击。攻击者通过在网站注入恶意脚本,使之在用户的浏览器上运行,从而盗取用户的信息如cookie等。XSS的本质是因为网站没有对恶意代码进行过滤,与正常的代码混合在一起了,浏览器没有办法分辨哪些脚本是可信的,从而导致了恶意代码的执......
  • Linux openssh问题解决: Permission denied, please try again
    1.vim打开sshd_config文件vim/etc/ssh/sshd_config2.搜索PermitRootLogin ,将 PermitRootLoginprohibie-password 改为如下:PermitRootLoginyes  ......
  • 从0开始构建WSL工作平台(VSCode、ssh、Xftp、Docker)
    一、命令行界面安装1、win+S,搜索PowerShell,右键管理员身份运行2、输入命令,启用 适用于Linux的Windows子系统 功能dism.exe/online/enable-feature/featurename:Microsoft-Windows-Subsystem-Linux/all/norestart3、在MicrosoftStore中下载中意的Linux分发版(如Ubu......
  • 亚马逊云服务器aws ssh无法登录的解决问题记录
    一、涉及命令1、备份原sshd配置文件cp/etc/ssh/sshd_config/etc/ssh/sshd_config.backup2、修改sshd配置文件:/etc/ssh/sshd_config3、查看当前活跃的用户列表:w4、查看用户:cat/etc/passwd#对于cat/etc/passwd的替换,可以更精简cat/etc/passwd|grep-vnologi......
  • 使用 powershell 安装 openssh
    1. 若要使用PowerShell安装OpenSSH,请先以管理员身份运行PowerShell(win+x快捷键进行打开)。为了确保OpenSSH可用,请运行以下cmdlet:Get-WindowsCapability-Online|Where-ObjectName-like'OpenSSH*'  2. 如果两者均尚未安装,则此操作应返回以下输出:Name:Op......
  • SSH连服务器时,连接不上,出现以下错误的原因与解决办法
    https://blog.csdn.net/zhoupenghui168/article/details/124165270?ops_request_misc=&request_id=&biz_id=102&utm_term=ps%20-e%20%7C%20grep%20ssh%E6%B2%A1%E5%8F%8D%E5%BA%94&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~d......
  • SSH端口转发
    本地转发:-Llocalport:remotehost:remotehostportsshserver选项:-f后台启用-N不打开远程shell,处于等待状态-g启用网关功能示例:ssh-L9527:telnetsrv:22-Nfg192.168.1.5当访问本机的9527的端口时,被加密后转发到sshsrv的ssh服务,再解密被转发到telnetsrv:......