- Struts2漏洞复现
Beyond My
漏洞复现struts安全java漏洞复现
一.S2-016复现打开测试靶场,测试该网站存在index.action路径漏洞原理:参数action的值redirect以及redirectAction没有正确过滤,导致ognl代码执行测试POC:2.1/index.action?redirect:%25{3*4}2.2/index.action?redirect:%25%7B3*4%7D(经Url编码)返回12,说明命令被执行了,即存在该漏洞
- 漏洞分析.Struts2
Jayden@gzm
strutsjava
S2-016简述在struts2中,DefaultActionMapper类支持以action:、redirect:、redirectAction:作为重定向前缀,但是这些前缀后面同时可以跟OGNL表达式,由于struts2没有对这些前缀做过滤,导致利用OGNL表达式调用Java静态方法执行任意系统命令。Payloadhttp://localhost:8080/s2_016_war_explode
- struts-default常用的跳转结果类型
暗香抚动
dispatcher转发,不指定默认为转发redirect重定向redirectAction重定向到action资源stream文件下载时用,文件流
- 编码以及Action中的result的各种转发类型
exmexm
result配置类似Struts1中的forward,但是Strut2中提供了多种结果类型,常用的类型有:dispatcher(默认值)、redirect、redirectAction、plainText1、默认的内部转发(属于同一个请求)/WEB-INF/page/hello.jsp2、重定向转发,已经不在同一个请求内了/view.jsp?id=${id}在result中还可以使用${属性名}表
- Struts2 关于返回type="chain"的用法.
caolijunmingyan
Struts2开发
见到struts.xml当中有这么个配置showArticle这个type="chain"是什么意思呢? 功能与redirect的action转发类似,不过与redirectaction转发功能不同的是它可以将Action中的数据一直保存在同一个HTTP请求中。Struts2支持的不同类型的返回结果为:ChainResult-->type="chain"用来处理Action链DispatcherR
- struts2 中redirectAction如何传递参数!(转)
学路漫漫
java相关1StrutsredirectJSP
struts2action提交成功后一般会转到某一jsp。但有时候需要跳到某一action,一般会用如下方法:Xml代码actionNameactionName或者Xml代码actionName.actionactionName.action如果这个action后面要带参数,比如xxxAction?id=xxxx也可以搞定,用下面的方法:Xml代码viewCampaignDetail?campai
- Struts2 result视图跳转方式(转)
神气的猫
JavaEEstruts2.0redirect
首先redirect:标准的重定向,用于在某一个action处理结束后,重定向到新的jsp(视图),重定向和转发的区别,这里一个明显的表象就是会丢失值栈范围内的所有携带参数,相当于浏览器重新请求了一个新的视图,URL也会显示请求的页面视图地址(Address);redirectAction:顾名思义,redirect用于普通的转向到某一视图,redirectAction即用来重定向到新的actio
- Struts2视图转发类型
li_zhang_hb
Struts2Struts2视图
在Struts2中result的视图转发类型比较常用的有四种:dispathcher(默认值):服务器内部请求转发类型;redirect:重定向到某个jsp文件;redirectAction:重定向到某个action;plainText:他主要用在输出页面源代码。在struts.xml中配置如下:125678910/redirect.jsp?username=${Savepath}在web.xml
- 如何利用Struts2漏洞绕过防火墙获取Root权限
qq_27446553
java-hack
本文我要分享的是关于Apachestruts2CVE-2013–2251漏洞的,由于该漏洞可以导致远程代码执行,曾一度被广泛滥用。该漏洞原理在于,通过操纵前缀为“action:”/”redirect:”/”redirectAction:”的参数,在Struts低于2.3.15的版本框架中实现远程代码执行。此次测试中,我不仅绕过了WAF防火墙实现远程代码执行,还利用了某Linux提权漏洞获取了目标服
- Apache Struts2 多个前缀参数远程命令执行漏洞及测试方法
皓月微风
随笔
受影响的软件及系统:====================ApacheStruts2.0.0-ApacheStruts2.3.15未受影响的软件及系统:======================ApacheStruts2.3.15.1及以上版本综述:======ApacheStruts2在处理action、redirect、和redirectAction前缀参数时存在一个安全漏洞,攻击者可以通
- action cannot be found in the namespace/
GreetTuring
javaweb
如果你在struts.xml中使用了type="redirectAction"会出现错误按照下面的方法就可以解决了。/campAction_warn/Login.jsp方法:Window-->Preference-->Myeclipse-->Validation-->去掉struts2Validator后的Build列勾确认
- 关于元素的type属性
黎涛note
•type属性表明了本次应答结果的类型。该属性的取值可使用struts-default.xml中预定义的result-type:dispatcher//(默认值)转发到jsp页面;stream//文件流redirect//重定向(可以转到jsp或action)redirectAction//重定向到另一Action•redirect与redirectAction的使用区别:1、使用redirect
- alias拦截器的使用
weixin_33994444
在SSH项目中,有时需要由一个Action跳转到另一个Action。有两种方式可以实现Action之间的跳转,一种是chain,另一种是redirectAction,这两种方式之间的区别是chain是在服务器上跳转,可以实现不同Action之间的数据共享;而redirectAction是在客户端进行跳转。使用chain在不同的Action之间传递参数值,这个功能可以通过alias拦截器来实现。1.
- MVC知识点总结
weixin_30752699
1:Action方法前,使用AcceptVerbs标签来指定方法支持的Get/Post类型,比如:[AcceptVerbs(HttpVerbs.Post)]2:使用Controler的UpdateModel()方法,可以获取Form中提交的数据(通过反射)3:使用RedirectAction()方法而不是直接返回View的方式来处理类似Edit这样的页面,可以避免重复提交,也符合MVC的思想。4:
- Struts2-016命令执行漏洞
MX-LQ
漏洞复现
Struts2-016命令执行漏洞一:前言CVE-2013-2251漏洞概述:Struts2是第二代基于Model-View-Controller(MVC)模型的java企业级web应用框架。它是WebWork和Struts社区合并后的产物。ApacheStruts2的action:、redirect:和redirectAction:前缀参数在实现其功能的过程中使用了Ognl表达式,并将用户通过U
- 【java框架】Struts2(3) -- Struts2结果视图及参数接收
人无名,则可专心练剑
1.Struts2的结果视图Struts2的每一个atcion都可以有不同的结果返回方式,在result中返回结果类型type属性有11种返回结果类型的方式。最主要最常用的有redirect、redirectAction、dispather三种跳转方式。具体跳转方式的type类型可以在struts-default.xml中查找到,具体如下:1.1.redirectAction配置redirectA
- SSI测试-action跳转至另一个action
陶宁
注册页面完成后跳转至查询页面并触发查询用户青岛action1、在struts.xml文件中添加一个redirectAction类型的result${successPath}${successPath}${redirectActionPath}2、在loginAction的页面增加publicStringredirectActionPath;增加get和set方法3、在register方法中setR
- Struts-S2-017漏洞利用(含环境搭建、含POC)
心如水_0b05
struts-s2-017此文仅供大家交流学习,严禁非法使用一、参考网址:http://www.freebuf.com/vuls/11220.html二、影响版本:Struts2.0.0-Struts2.3.15三、漏洞介绍:Struts2DefaultActionMapper用于通过使用“redirect:”或“redirectAction:”前缀参数来支持短路导航状态更改的方法,然后是所需的重
- [Struts2]9-Result配置
我相信你爱过gg
常用结果类型chain-Action处理完成用户请求之后,转发到下一个Action继续处理。redirectAction-重定向到一个Actiondispatcher-默认值。转发到jsp页面redirect-重定向到jsp页面也就是说两个用来请求jsp,两个用来请求Action。全局Result与局部Result:Result元素放在Action元素中,就是局部result。Result元素放在
- EasyUI初步使用课题的展示(第六天)
setone
第六天;构思:1.在struts.xml里面的action通过type="redirectAction"直接在struts.xml里面跳转到另外一个action,然后执行2.自动查询所有科目3.根据放进Session的userinfo去ErrorsubjectDAO里面找到错题信息我们需要知道El表达式ognl表达式今天我们要完成的样式如下图image.png这是EasyUI其中的一个框架,贴上代
- struts2配置result
andrew7676
Javastruts2
阅读更多1.struts2配置result新建项目HeadFirstStruts2Chap02_071)type默认是dispatcher内部转发2)type为redirect重定向3)type为chain链条4)type为redirectAction重定向到action5)result全局配置HelloAction.javapackagecom.andrew.action;importcom.o
- Struts2知识总结
CoderBruis
Struts2知识总结(一)Struts2会为每一个HTTP请求创建一个新的实例(二)关于dispatcher、redirect、redirectAction、Chaindispatcher:解释为转发;只涉及一个线程,数据能够共享,请求request中存放的变量不会失效,就像把两个页面拼到了一起。而且dispatcher是服务跳转,浏览器不知道它所请求的具体资源来源,浏览器的地址栏不会变。edi
- struts.xml文件里面的type类型
dx_shendu
SSHstruts
dispatcher:用来转发到指定页面,通常处理JSP,【type属性默认值】redirect:重定向到一个URL。chain:用来处理Action链。redirectAction:重定向到一个Action。redirect-action:重定向到一个Action,与上面的一致。stream:向浏览器发送InputSream对象,通常用来处理文件下载,还可用于返回AJAX数据。。velocity
- Struts2拦截器 关于解决登录的问题
南城琉璃
拦截器的工作原理如图拦截器是由每一个action请求(request)都包装在一系列的拦截器的内部,通过redirectAction再一次发送请求。拦截器可以在Action执行直线做相似的操作也可以在Action执行直后做回收操作。我们可以让每一个Action既可以将操作转交给下面的拦截器,Action也可以直接退出操作返回客户既定的画面。接下来我们该如何定义一个拦截器:自定义一个拦截器如下:1、
- Struts2拦截器 解决登录问题
南城琉璃
一、了解Struts2拦截器【Interceptor】拦截器的工作原理如图拦截器是由每一个action请求(request)都包装在一系列的拦截器的内部,通过redirectAction再一次发送请求。拦截器可以在Action执行直线做相似的操作也可以在Action执行直后做回收操作。我们可以让每一个Action既可以将操作转交给下面的拦截器,Action也可以直接退出操作返回客户既定的画面。接下
- stract2中action中的type中redirectActio,redirectAction,chain的详解
m_wise
struts2跳转类型resulttype=chain、dispatcher、redirect(redirect-action)dispatcher为默认跳转类型,用于返回一个视图资源(如:jsp)当使用type=“redirectAction”或type=“redirect”提交到一个action并且需要传递一个参数时。这里是有区别的:(1).type=“redirectAction”时,参数只
- Struts.xml文件 action属性详解
qq_24665727
Struts2--ation
阅读更多action2转发到不同包(不同名称空间)下的另一个动作使用的是注入的思想,在执行之重定向之前,会先获取这两个参数的值调用的就是setNamespace("/n2")和setActionName("action3")/n2action3redirectAction:重定向到另一个动作重定向到同包(同名称空间)下的另一个动作action2重定向不同包(不同名称空间)下的另一个动作使用的是注入
- Struts.xml文件 action属性详解
qq_24665727
Struts2--ation
action2
转发到不同包(不同名称空间)下的另一个动作
使用的是注入的思想,在执行之重定向之前,会先获取这两个参数的值
调用的就是setNamespace("/n2")和setActionName("action3")
/n2
action3
redirectAction:重定向到另一个动作
重定向到同包(同名称空间)下的另一个动作
action
- JavaWeb开发中alias拦截器的使用方法
MSTK
在SSH项目中,有时需要由一个Action跳转到另一个Action。有两种方式可以实现Action之间的跳转,一种是chain,另一种是redirectAction,这两种方式之间的区别是chain是在服务器上跳转,可以实现不同Action之间的数据共享;而redirectAction是在客户端进行跳转。使用chain在不同的Action之间传递参数值,这个功能可以通过alias拦截器来实现。1.
- Struts2学习笔记(8)-Result常用类型
meaijojo
Result也是Struts2比较重要的一部分,在Result的配置中常用的有四种类型:dispatcher、redirect、chain和redirectAction,在这四种中又以前两种最为常见。例:/r1.jsp/r2.jspr1r21、dispatcher,最常用-服务器端跳转,即当用户访问某个Action时,后台服务器会自从查找对应的result是哪个jsp页面,从而跳转过去,这个时候在
- 面向对象面向过程
3213213333332132
java
面向对象:把要完成的一件事,通过对象间的协作实现。
面向过程:把要完成的一件事,通过循序依次调用各个模块实现。
我把大象装进冰箱这件事为例,用面向对象和面向过程实现,都是用java代码完成。
1、面向对象
package bigDemo.ObjectOriented;
/**
* 大象类
*
* @Description
* @author FuJian
- Java Hotspot: Remove the Permanent Generation
bookjovi
HotSpot
openjdk上关于hotspot将移除永久带的描述非常详细,http://openjdk.java.net/jeps/122
JEP 122: Remove the Permanent Generation
Author Jon Masamitsu
Organization Oracle
Created 2010/8/15
Updated 2011/
- 正则表达式向前查找向后查找,环绕或零宽断言
dcj3sjt126com
正则表达式
向前查找和向后查找
1. 向前查找:根据要匹配的字符序列后面存在一个特定的字符序列(肯定式向前查找)或不存在一个特定的序列(否定式向前查找)来决定是否匹配。.NET将向前查找称之为零宽度向前查找断言。
对于向前查找,出现在指定项之后的字符序列不会被正则表达式引擎返回。
2. 向后查找:一个要匹配的字符序列前面有或者没有指定的
- BaseDao
171815164
seda
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class BaseDao {
public Conn
- Ant标签详解--Java命令
g21121
Java命令
这一篇主要介绍与java相关标签的使用 终于开始重头戏了,Java部分是我们关注的重点也是项目中用处最多的部分。
1
- [简单]代码片段_电梯数字排列
53873039oycg
代码
今天看电梯数字排列是9 18 26这样呈倒N排列的,写了个类似的打印例子,如下:
import java.util.Arrays;
public class 电梯数字排列_S3_Test {
public static void main(S
- Hessian原理
云端月影
hessian原理
Hessian 原理分析
一. 远程通讯协议的基本原理
网络通信需要做的就是将流从一台计算机传输到另外一台计算机,基于传输协议和网络 IO 来实现,其中传输协议比较出名的有 http 、 tcp 、 udp 等等, http 、 tcp 、 udp 都是在基于 Socket 概念上为某类应用场景而扩展出的传输协
- 区分Activity的四种加载模式----以及Intent的setFlags
aijuans
android
在多Activity开发中,有可能是自己应用之间的Activity跳转,或者夹带其他应用的可复用Activity。可能会希望跳转到原来某个Activity实例,而不是产生大量重复的Activity。
这需要为Activity配置特定的加载模式,而不是使用默认的加载模式。 加载模式分类及在哪里配置
Activity有四种加载模式:
standard
singleTop
- hibernate几个核心API及其查询分析
antonyup_2006
html.netHibernatexml配置管理
(一) org.hibernate.cfg.Configuration类
读取配置文件并创建唯一的SessionFactory对象.(一般,程序初始化hibernate时创建.)
Configuration co
- PL/SQL的流程控制
百合不是茶
oraclePL/SQL编程循环控制
PL/SQL也是一门高级语言,所以流程控制是必须要有的,oracle数据库的pl/sql比sqlserver数据库要难,很多pl/sql中有的sqlserver里面没有
流程控制;
分支语句 if 条件 then 结果 else 结果 end if ;
条件语句 case when 条件 then 结果;
循环语句 loop
- 强大的Mockito测试框架
bijian1013
mockito单元测试
一.自动生成Mock类 在需要Mock的属性上标记@Mock注解,然后@RunWith中配置Mockito的TestRunner或者在setUp()方法中显示调用MockitoAnnotations.initMocks(this);生成Mock类即可。二.自动注入Mock类到被测试类 &nbs
- 精通Oracle10编程SQL(11)开发子程序
bijian1013
oracle数据库plsql
/*
*开发子程序
*/
--子程序目是指被命名的PL/SQL块,这种块可以带有参数,可以在不同应用程序中多次调用
--PL/SQL有两种类型的子程序:过程和函数
--开发过程
--建立过程:不带任何参数
CREATE OR REPLACE PROCEDURE out_time
IS
BEGIN
DBMS_OUTPUT.put_line(systimestamp);
E
- 【EhCache一】EhCache版Hello World
bit1129
Hello world
本篇是EhCache系列的第一篇,总体介绍使用EhCache缓存进行CRUD的API的基本使用,更细节的内容包括EhCache源代码和设计、实现原理在接下来的文章中进行介绍
环境准备
1.新建Maven项目
2.添加EhCache的Maven依赖
<dependency>
<groupId>ne
- 学习EJB3基础知识笔记
白糖_
beanHibernatejbosswebserviceejb
最近项目进入系统测试阶段,全赖袁大虾领导有力,保持一周零bug记录,这也让自己腾出不少时间补充知识。花了两天时间把“传智播客EJB3.0”看完了,EJB基本的知识也有些了解,在这记录下EJB的部分知识,以供自己以后复习使用。
EJB是sun的服务器端组件模型,最大的用处是部署分布式应用程序。EJB (Enterprise JavaBean)是J2EE的一部分,定义了一个用于开发基
- angular.bootstrap
boyitech
AngularJSAngularJS APIangular中文api
angular.bootstrap
描述:
手动初始化angular。
这个函数会自动检测创建的module有没有被加载多次,如果有则会在浏览器的控制台打出警告日志,并且不会再次加载。这样可以避免在程序运行过程中许多奇怪的问题发生。
使用方法: angular .
- java-谷歌面试题-给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数
bylijinnan
java
public class SearchInShiftedArray {
/**
* 题目:给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数。
* 请在这个特殊数组中找出给定的整数。
* 解答:
* 其实就是“旋转数组”。旋转数组的最小元素见http://bylijinnan.iteye.com/bl
- 天使还是魔鬼?都是我们制造
ducklsl
生活教育情感
----------------------------剧透请原谅,有兴趣的朋友可以自己看看电影,互相讨论哦!!!
从厦门回来的动车上,无意中瞟到了书中推荐的几部关于儿童的电影。当然,这几部电影可能会另大家失望,并不是类似小鬼当家的电影,而是关于“坏小孩”的电影!
自己挑了两部先看了看,但是发现看完之后,心里久久不能平
- [机器智能与生物]研究生物智能的问题
comsci
生物
我想,人的神经网络和苍蝇的神经网络,并没有本质的区别...就是大规模拓扑系统和中小规模拓扑分析的区别....
但是,如果去研究活体人类的神经网络和脑系统,可能会受到一些法律和道德方面的限制,而且研究结果也不一定可靠,那么希望从事生物神经网络研究的朋友,不如把
- 获取Android Device的信息
dai_lm
android
String phoneInfo = "PRODUCT: " + android.os.Build.PRODUCT;
phoneInfo += ", CPU_ABI: " + android.os.Build.CPU_ABI;
phoneInfo += ", TAGS: " + android.os.Build.TAGS;
ph
- 最佳字符串匹配算法(Damerau-Levenshtein距离算法)的Java实现
datamachine
java算法字符串匹配
原文:http://www.javacodegeeks.com/2013/11/java-implementation-of-optimal-string-alignment.html------------------------------------------------------------------------------------------------------------
- 小学5年级英语单词背诵第一课
dcj3sjt126com
englishword
long 长的
show 给...看,出示
mouth 口,嘴
write 写
use 用,使用
take 拿,带来
hand 手
clever 聪明的
often 经常
wash 洗
slow 慢的
house 房子
water 水
clean 清洁的
supper 晚餐
out 在外
face 脸,
- macvim的使用实战
dcj3sjt126com
macvim
macvim用的是mac里面的vim, 只不过是一个GUI的APP, 相当于一个壳
1. 下载macvim
https://code.google.com/p/macvim/
2. 了解macvim
:h vim的使用帮助信息
:h macvim
- java二分法查找
蕃薯耀
java二分法查找二分法java二分法
java二分法查找
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月23日 11:40:03 星期二
http:/
- Spring Cache注解+Memcached
hanqunfeng
springmemcached
Spring3.1 Cache注解
依赖jar包:
<!-- simple-spring-memcached -->
<dependency>
<groupId>com.google.code.simple-spring-memcached</groupId>
<artifactId>simple-s
- apache commons io包快速入门
jackyrong
apache commons
原文参考
http://www.javacodegeeks.com/2014/10/apache-commons-io-tutorial.html
Apache Commons IO 包绝对是好东西,地址在http://commons.apache.org/proper/commons-io/,下面用例子分别介绍:
1) 工具类
2
- 如何学习编程
lampcy
java编程C++c
首先,我想说一下学习思想.学编程其实跟网络游戏有着类似的效果.开始的时候,你会对那些代码,函数等产生很大的兴趣,尤其是刚接触编程的人,刚学习第一种语言的人.可是,当你一步步深入的时候,你会发现你没有了以前那种斗志.就好象你在玩韩国泡菜网游似的,玩到一定程度,每天就是练级练级,完全是一个想冲到高级别的意志力在支持着你.而学编程就更难了,学了两个月后,总是觉得你好象全都学会了,却又什么都做不了,又没有
- 架构师之spring-----spring3.0新特性的bean加载控制@DependsOn和@Lazy
nannan408
Spring3
1.前言。
如题。
2.描述。
@DependsOn用于强制初始化其他Bean。可以修饰Bean类或方法,使用该Annotation时可以指定一个字符串数组作为参数,每个数组元素对应于一个强制初始化的Bean。
@DependsOn({"steelAxe","abc"})
@Comp
- Spring4+quartz2的配置和代码方式调度
Everyday都不同
代码配置spring4quartz2.x定时任务
前言:这些天简直被quartz虐哭。。因为quartz 2.x版本相比quartz1.x版本的API改动太多,所以,只好自己去查阅底层API……
quartz定时任务必须搞清楚几个概念:
JobDetail——处理类
Trigger——触发器,指定触发时间,必须要有JobDetail属性,即触发对象
Scheduler——调度器,组织处理类和触发器,配置方式一般只需指定触发
- Hibernate入门
tntxia
Hibernate
前言
使用面向对象的语言和关系型的数据库,开发起来很繁琐,费时。由于现在流行的数据库都不面向对象。Hibernate 是一个Java的ORM(Object/Relational Mapping)解决方案。
Hibernte不仅关心把Java对象对应到数据库的表中,而且提供了请求和检索的方法。简化了手工进行JDBC操作的流程。
如
- Math类
xiaoxing598
Math
一、Java中的数字(Math)类是final类,不可继承。
1、常数 PI:double圆周率 E:double自然对数
2、截取(注意方法的返回类型) double ceil(double d) 返回不小于d的最小整数 double floor(double d) 返回不大于d的整最大数 int round(float f) 返回四舍五入后的整数 long round