在easyjweb应用中关于acegi安全配置的增强

  在easyjweb的应用程序中,我们习惯通过easyJWebCommand这一参数来指定服务器端控制器的执行命令。比如newsDocManage.ejf?easyJWebCommand=edit&id=1,将执行NewsDocManageAction中的doEdit方法。

  在acegi中,最简单也是最常用的权限控制是基于url拦截的权限控制。比如,为了对添加文章进行权限控制,我们需要添加一个类似如下URL资源:/newsDocManage.ejf/?easyJWebCommand=add.*。这样当用户点击这一连接的时候,将会进一步检查用户对该URL的访问权限,从而达到保护。

  在EasyJWeb的快速应用开发构架中,easyJWebCommand这一个命令参数都是以隐藏表示元素的形式存在的,比如,在表单中一般会包含下面的元素:。而大我数表单都是以post方式提交的。此时就无法使用基于URL拦截的方式对doEdit方法进行资源描述及权限控制,而只能使用基于方法调用的资源来描述。但acegi的方法调用需要使用AOP,特别是代理Bean的配置也比较麻烦,而且实现应用中是不会直接像acegi的示例那样直接修改配置文件的,而且这是MVC一级的东西,我们不宜使用AOP,(当然,直接通过AOP配置业务逻辑层组件的除外)。

  在今天更新的acegi集成的开发框架版本中,增加对NewsDocManageAction的doEdit方法进行描述及权限控制的支持。也就是说,不管使用get或者是post。在基于easyjweb的应用中,都可以直接使用get的方式来进行权限描述。比如上面的doEdit方法,可以直接使用下面的资源描述:/newsDocManage.ejf/?easyJWebCommand=edit.*
 
  这样,不管是post提交还是get提交,都可以使用一致的方式的对控制器中的方法进行权限设置了。


  注意要使用这个功能,需要调整一下web.xml的配置,特别是filter的配置。修改的事项:
  1、CharsetFilter需要放在Acegi Filter Chain Proxy的前面
  2、两个filter者url-pattern最好保持一致,否则就会在有的地方出现乱码。
  修改后的web.xml文件如下:

 

xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
 xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation
="http://java.sun.com/xml/ns/j2ee 
 http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
>
 
<context-param>
  
<param-name>easyjwebConfigLocation</param-name>
  
<param-value>/WEB-INF/mvc.xml,/WEB-INF/mvc-tms.xml</param-value>
 
</context-param>

 

 
<servlet>
  
<servlet-name>easyjf</servlet-name>
  
<servlet-class>com.easyjf.web.ActionServlet</servlet-class>
  
<load-on-startup>1</load-on-startup>
 
</servlet>

 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>*.ejf</url-pattern>
 
</servlet-mapping>
 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>/ejf/*</url-pattern>
 
</servlet-mapping>


 
<filter>
  
<filter-name>CharsetFilter</filter-name>
  
<filter-class>com.easyjf.web.CharsetFilter</filter-class>
  
<init-param>
   
<param-name>encoding</param-name>
   
<param-value>UTF-8</param-value>
  
</init-param>
  
<init-param>
   
<param-name>ignore</param-name>
   
<param-value>true</param-value>
  
</init-param>  
 
</filter>
 
 
<filter-mapping>
  
<filter-name>CharsetFilter</filter-name>
  
<url-pattern>/*</url-pattern>
 
</filter-mapping>

<filter>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<filter-class>org.acegisecurity.util.FilterToBeanProxy</filter-class>
  
<init-param>
    
<param-name>targetClass</param-name>
    
<param-value>org.acegisecurity.util.FilterChainProxy</param-value>   
  
</init-param>
  
<init-param>
   
<param-name>init</param-name>
    
<param-value>lazy</param-value>
    
</init-param>
</filter>
<filter-mapping>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<url-pattern>/*</url-pattern>
</filter-mapping>

</web-app> 



  在easyjweb的应用程序中,我们习惯通过easyJWebCommand这一参数来指定服务器端控制器的执行命令。比如newsDocManage.ejf?easyJWebCommand=edit&id=1,将执行NewsDocManageAction中的doEdit方法。

  在acegi中,最简单也是最常用的权限控制是基于url拦截的权限控制。比如,为了对添加文章进行权限控制,我们需要添加一个类似如下URL资源:/newsDocManage.ejf/?easyJWebCommand=add.*。这样当用户点击这一连接的时候,将会进一步检查用户对该URL的访问权限,从而达到保护。

  在EasyJWeb的快速应用开发构架中,easyJWebCommand这一个命令参数都是以隐藏表示元素的形式存在的,比如,在表单中一般会包含下面的元素:。而大我数表单都是以post方式提交的。此时就无法使用基于URL拦截的方式对doEdit方法进行资源描述及权限控制,而只能使用基于方法调用的资源来描述。但acegi的方法调用需要使用AOP,特别是代理Bean的配置也比较麻烦,而且实现应用中是不会直接像acegi的示例那样直接修改配置文件的,而且这是MVC一级的东西,我们不宜使用AOP,(当然,直接通过AOP配置业务逻辑层组件的除外)。

  在今天更新的acegi集成的开发框架版本中,增加对NewsDocManageAction的doEdit方法进行描述及权限控制的支持。也就是说,不管使用get或者是post。在基于easyjweb的应用中,都可以直接使用get的方式来进行权限描述。比如上面的doEdit方法,可以直接使用下面的资源描述:/newsDocManage.ejf/?easyJWebCommand=edit.*
 
  这样,不管是post提交还是get提交,都可以使用一致的方式的对控制器中的方法进行权限设置了。


  注意要使用这个功能,需要调整一下web.xml的配置,特别是filter的配置。修改的事项:
  1、CharsetFilter需要放在Acegi Filter Chain Proxy的前面
  2、两个filter者url-pattern最好保持一致,否则就会在有的地方出现乱码。
  修改后的web.xml文件如下:

 

xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
 xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation
="http://java.sun.com/xml/ns/j2ee 
 http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
>
 
<context-param>
  
<param-name>easyjwebConfigLocation</param-name>
  
<param-value>/WEB-INF/mvc.xml,/WEB-INF/mvc-tms.xml</param-value>
 
</context-param>

 

 
<servlet>
  
<servlet-name>easyjf</servlet-name>
  
<servlet-class>com.easyjf.web.ActionServlet</servlet-class>
  
<load-on-startup>1</load-on-startup>
 
</servlet>

 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>*.ejf</url-pattern>
 
</servlet-mapping>
 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>/ejf/*</url-pattern>
 
</servlet-mapping>


 
<filter>
  
<filter-name>CharsetFilter</filter-name>
  
<filter-class>com.easyjf.web.CharsetFilter</filter-class>
  
<init-param>
   
<param-name>encoding</param-name>
   
<param-value>UTF-8</param-value>
  
</init-param>
  
<init-param>
   
<param-name>ignore</param-name>
   
<param-value>true</param-value>
  
</init-param>  
 
</filter>
 
 
<filter-mapping>
  
<filter-name>CharsetFilter</filter-name>
  
<url-pattern>/*</url-pattern>
 
</filter-mapping>

<filter>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<filter-class>org.acegisecurity.util.FilterToBeanProxy</filter-class>
  
<init-param>
    
<param-name>targetClass</param-name>
    
<param-value>org.acegisecurity.util.FilterChainProxy</param-value>   
  
</init-param>
  
<init-param>
   
<param-name>init</param-name>
    
<param-value>lazy</param-value>
    
</init-param>
</filter>
<filter-mapping>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<url-pattern>/*</url-pattern>
</filter-mapping>

</web-app> 



  在easyjweb的应用程序中,我们习惯通过easyJWebCommand这一参数来指定服务器端控制器的执行命令。比如newsDocManage.ejf?easyJWebCommand=edit&id=1,将执行NewsDocManageAction中的doEdit方法。

  在acegi中,最简单也是最常用的权限控制是基于url拦截的权限控制。比如,为了对添加文章进行权限控制,我们需要添加一个类似如下URL资源:/newsDocManage.ejf/?easyJWebCommand=add.*。这样当用户点击这一连接的时候,将会进一步检查用户对该URL的访问权限,从而达到保护。

  在EasyJWeb的快速应用开发构架中,easyJWebCommand这一个命令参数都是以隐藏表示元素的形式存在的,比如,在表单中一般会包含下面的元素:。而大我数表单都是以post方式提交的。此时就无法使用基于URL拦截的方式对doEdit方法进行资源描述及权限控制,而只能使用基于方法调用的资源来描述。但acegi的方法调用需要使用AOP,特别是代理Bean的配置也比较麻烦,而且实现应用中是不会直接像acegi的示例那样直接修改配置文件的,而且这是MVC一级的东西,我们不宜使用AOP,(当然,直接通过AOP配置业务逻辑层组件的除外)。

  在今天更新的acegi集成的开发框架版本中,增加对NewsDocManageAction的doEdit方法进行描述及权限控制的支持。也就是说,不管使用get或者是post。在基于easyjweb的应用中,都可以直接使用get的方式来进行权限描述。比如上面的doEdit方法,可以直接使用下面的资源描述:/newsDocManage.ejf/?easyJWebCommand=edit.*
 
  这样,不管是post提交还是get提交,都可以使用一致的方式的对控制器中的方法进行权限设置了。


  注意要使用这个功能,需要调整一下web.xml的配置,特别是filter的配置。修改的事项:
  1、CharsetFilter需要放在Acegi Filter Chain Proxy的前面
  2、两个filter者url-pattern最好保持一致,否则就会在有的地方出现乱码。
  修改后的web.xml文件如下:

 

xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
 xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation
="http://java.sun.com/xml/ns/j2ee 
 http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
>
 
<context-param>
  
<param-name>easyjwebConfigLocation</param-name>
  
<param-value>/WEB-INF/mvc.xml,/WEB-INF/mvc-tms.xml</param-value>
 
</context-param>

 

 
<servlet>
  
<servlet-name>easyjf</servlet-name>
  
<servlet-class>com.easyjf.web.ActionServlet</servlet-class>
  
<load-on-startup>1</load-on-startup>
 
</servlet>

 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>*.ejf</url-pattern>
 
</servlet-mapping>
 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>/ejf/*</url-pattern>
 
</servlet-mapping>


 
<filter>
  
<filter-name>CharsetFilter</filter-name>
  
<filter-class>com.easyjf.web.CharsetFilter</filter-class>
  
<init-param>
   
<param-name>encoding</param-name>
   
<param-value>UTF-8</param-value>
  
</init-param>
  
<init-param>
   
<param-name>ignore</param-name>
   
<param-value>true</param-value>
  
</init-param>  
 
</filter>
 
 
<filter-mapping>
  
<filter-name>CharsetFilter</filter-name>
  
<url-pattern>/*</url-pattern>
 
</filter-mapping>

<filter>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<filter-class>org.acegisecurity.util.FilterToBeanProxy</filter-class>
  
<init-param>
    
<param-name>targetClass</param-name>
    
<param-value>org.acegisecurity.util.FilterChainProxy</param-value>   
  
</init-param>
  
<init-param>
   
<param-name>init</param-name>
    
<param-value>lazy</param-value>
    
</init-param>
</filter>
<filter-mapping>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<url-pattern>/*</url-pattern>
</filter-mapping>

</web-app> 



  在easyjweb的应用程序中,我们习惯通过easyJWebCommand这一参数来指定服务器端控制器的执行命令。比如newsDocManage.ejf?easyJWebCommand=edit&id=1,将执行NewsDocManageAction中的doEdit方法。

  在acegi中,最简单也是最常用的权限控制是基于url拦截的权限控制。比如,为了对添加文章进行权限控制,我们需要添加一个类似如下URL资源:/newsDocManage.ejf/?easyJWebCommand=add.*。这样当用户点击这一连接的时候,将会进一步检查用户对该URL的访问权限,从而达到保护。

  在EasyJWeb的快速应用开发构架中,easyJWebCommand这一个命令参数都是以隐藏表示元素的形式存在的,比如,在表单中一般会包含下面的元素:。而大我数表单都是以post方式提交的。此时就无法使用基于URL拦截的方式对doEdit方法进行资源描述及权限控制,而只能使用基于方法调用的资源来描述。但acegi的方法调用需要使用AOP,特别是代理Bean的配置也比较麻烦,而且实现应用中是不会直接像acegi的示例那样直接修改配置文件的,而且这是MVC一级的东西,我们不宜使用AOP,(当然,直接通过AOP配置业务逻辑层组件的除外)。

  在今天更新的acegi集成的开发框架版本中,增加对NewsDocManageAction的doEdit方法进行描述及权限控制的支持。也就是说,不管使用get或者是post。在基于easyjweb的应用中,都可以直接使用get的方式来进行权限描述。比如上面的doEdit方法,可以直接使用下面的资源描述:/newsDocManage.ejf/?easyJWebCommand=edit.*
 
  这样,不管是post提交还是get提交,都可以使用一致的方式的对控制器中的方法进行权限设置了。


  注意要使用这个功能,需要调整一下web.xml的配置,特别是filter的配置。修改的事项:
  1、CharsetFilter需要放在Acegi Filter Chain Proxy的前面
  2、两个filter者url-pattern最好保持一致,否则就会在有的地方出现乱码。
  修改后的web.xml文件如下:

 

xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
 xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation
="http://java.sun.com/xml/ns/j2ee 
 http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
>
 
<context-param>
  
<param-name>easyjwebConfigLocation</param-name>
  
<param-value>/WEB-INF/mvc.xml,/WEB-INF/mvc-tms.xml</param-value>
 
</context-param>

 

 
<servlet>
  
<servlet-name>easyjf</servlet-name>
  
<servlet-class>com.easyjf.web.ActionServlet</servlet-class>
  
<load-on-startup>1</load-on-startup>
 
</servlet>

 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>*.ejf</url-pattern>
 
</servlet-mapping>
 
<servlet-mapping>
  
<servlet-name>easyjf</servlet-name>
  
<url-pattern>/ejf/*</url-pattern>
 
</servlet-mapping>


 
<filter>
  
<filter-name>CharsetFilter</filter-name>
  
<filter-class>com.easyjf.web.CharsetFilter</filter-class>
  
<init-param>
   
<param-name>encoding</param-name>
   
<param-value>UTF-8</param-value>
  
</init-param>
  
<init-param>
   
<param-name>ignore</param-name>
   
<param-value>true</param-value>
  
</init-param>  
 
</filter>
 
 
<filter-mapping>
  
<filter-name>CharsetFilter</filter-name>
  
<url-pattern>/*</url-pattern>
 
</filter-mapping>

<filter>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<filter-class>org.acegisecurity.util.FilterToBeanProxy</filter-class>
  
<init-param>
    
<param-name>targetClass</param-name>
    
<param-value>org.acegisecurity.util.FilterChainProxy</param-value>   
  
</init-param>
  
<init-param>
   
<param-name>init</param-name>
    
<param-value>lazy</param-value>
    
</init-param>
</filter>
<filter-mapping>
  
<filter-name>Acegi Filter Chain Proxy</filter-name>
  
<url-pattern>/*</url-pattern>
</filter-mapping>

</web-app> 



内容概要:本文介绍了基于Koopman算子理论的模型预测控制(MPC)方法,用于非线性受控动力系统的状态估计与预测。通过将非线性系统近似为线性系统,利用数据驱动的方式构建Koopman观测器,实现对系统动态行为的有效建模与预测,并结合Matlab代码实现具体仿真案例,展示了该方法在处理复杂非线性系统中的可行性与优势。文中强调了状态估计在控制系统中的关键作用,特别是面对不确定性因素时,Koopman-MPC框架能够提供更为精确的预测性能。; 适合人群:具备一定控制理论基础和Matlab编程能力的研【状态估计】非线性受控动力系统的线性预测器——Koopman模型预测MPC(Matlab代码实现)究生、科研人员及从事自动化、电气工程、机械电子等相关领域的工程师;熟悉非线性系统建模与控制、对先进控制算法如MPC、状态估计感兴趣的技术人员。; 使用场景及目标:①应用于非线性系统的建模与预测控制设计,如机器人、航空航天、能源系统等领域;②用于提升含不确定性因素的动力系统状态估计精度;③为研究数据驱动型控制方法提供可复现的Matlab实现方案,促进理论与实际结合。; 阅读建议:建议读者结合提供的Matlab代码逐段理解算法实现流程,重点关注Koopman算子的构造、观测器设计及MPC优化求解部分,同时可参考文中提及的其他相关技术(如卡尔曼滤波、深度学习等)进行横向对比研究,以深化对该方法优势与局限性的认识。
内容概要:本文研究了基于物理信息神经网络(PINN)求解二阶常微分方程(ODE)边值问题的方法,并提供了完整的Matlab代码实现。文章通过将微分方程的物理规律嵌入神经网络损失函数中,利用神经网络的逼近能力求解边值问题,避免传统数值方法在网格划分和迭代收敛方面的局限性。文中详细介绍了PINN的基本原理、网络结构设计、损失函数构建及训练流程,并以典型二阶ODE边值问题为例进行仿真验证,展示了该方法的有效性和精度。此外,文档还附带多个相关科研方向的Matlab案例资源链接,涵盖状态估计、优PINN物理信息神经网络用于求解二阶常微分方程(ODE)的边值问题研究(Matlab代码实现)化调度、机器学习、信号处理等多个领域,突出其在科学研究中的实际应用价值。; 适合人群:具备一定数学基础和Matlab编程能力的理工科研究生、科研人员及从事科学计算、工程仿真等相关工作的技术人员。; 使用场景及目标:①用于求解传统数值方法难以处理的复杂或高维微分方程问题;②为科研工作者提供PINN方法的入门实践路径,推动其在物理建模、工程仿真等领域中的创新应用;③结合所提供的丰富资源拓展至电力系统、故障诊断、优化调度等交叉学科研究。; 阅读建议:建议读者结合文中的Matlab代码逐行理解PINN实现机制,动手复现并尝试修改方程形式与边界条件以加深理解,同时可参考附带资源扩展应用场景,提升科研效率与创新能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值