Java中用Servlet容器实现程序监听

分两步走:
  (1). 实现 javax.servlet.ServletContextListener 接口的两个方法:contextInitialized()和contextDestroyed()
  contextInitialized():当Servlet容器启动时会执行
  contextDestroyed():当Servlet容器停止时会执行
  (2). 在contextInitialized()中加入需要监听的程序,并由 java.util.Timer 的 schedule() 方法来控制监听程序执行的频率
  DEMO(这是我的一个短信回复监听的程序原型,精简了一下)
  ----------------------------------------------------------------
  ReplyListener.java
  ----------------------------------------------------------------
  package com.hanweb.jcms;
  import javax.servlet.*;
  public class ReplyListener implements ServletContextListener {
   private ReplyTimer rt = null;
   public void contextInitialized(ServletContextEvent event) {
   String status = "[SYS] SMS reply listener start .";
   event.getServletContext().log(status);
   System.out.println(status);
   rt = new ReplyTimer(1);
   rt.start();
   }
   public void contextDestroyed(ServletContextEvent event) {
   String status = "[SYS] SMS reply listener stop .";
   event.getServletContext().log(status);
   System.out.println(status);
   if (rt != null) {
   rt.stop();
   }
   }
  }
  ----------------------------------------------------------------
  ReplyTimer.java
  ----------------------------------------------------------------
  package com.hanweb.jcms;
  import java.util.*;
  public class ReplyTimer {
   private final Timer timer = new Timer();
   private final int min;
   public ReplyTimer(int minutes) {
   min = minutes;
   }
   public void start() {
   Date date = new Date();
   timer.schedule(new ReplyTask(), date, min * 60 * 1000);
   }
   public void stop() {
   timer.cancel();
   }
  }
  ----------------------------------------------------------------
  ReplyTask.java
  ----------------------------------------------------------------
  package com.hanweb.jcms;
  import java.util.*;
  public class ReplyTask extends TimerTask {
   public void doSomething() {
   System.out.println("[SYS] SMS reply listener running ");
   }
   public void run() {
   doSomething();
   }
  }
  将编译好的class文件放入WEB-INF/classes中,最后别忘记了在Servlet容器中当前WEB应用的web.xml中加入监听语句:
  <listener>
  <listener-class>com.hanweb.jcms.ReplyListener</listener-class>
  </listener>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中使用Security框架实现权限控制需要以下步骤: 1. 创建一个Security配置类,该类需要继承WebSecurityConfigurerAdapter类,并重写它的configure方法。 2. 在configure方法中配置HttpSecurity对象,设置需要保护的URL、访问该URL需要的权限等。 3. 实现UserDetailsService接口,该接口用于从数据库或其他数据源中获取用户信息,包括用户名、密码和角色等。 4. 在configure方法中调用authenticationManagerBean方法,将UserDetailsService对象传入,并使用PasswordEncoder对象加密密码。 5. 在控制器中使用@PreAuthorize注解,该注解可以在方法级别上实现权限控制,只有拥有相应角色的用户才能访问该方法。 示例代码如下: ```java @Configuration @EnableWebSecurity public class WebSecurityConfig extends WebSecurityConfigurerAdapter { @Autowired private UserDetailsService userDetailsService; @Override protected void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers("/admin/**").hasRole("ADMIN") .antMatchers("/user/**").hasRole("USER") .and() .formLogin().loginPage("/login").permitAll() .and() .logout().permitAll() .and().csrf().disable(); } @Autowired public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception { auth.userDetailsService(userDetailsService).passwordEncoder(passwordEncoder()); } @Bean public PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); } } ``` ```java @Service public class UserDetailsServiceImpl implements UserDetailsService { @Autowired private UserRepository userRepository; @Override public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException { User user = userRepository.findByUsername(username); if (user == null) { throw new UsernameNotFoundException(username); } List<GrantedAuthority> authorities = new ArrayList<>(); for (Role role : user.getRoles()) { authorities.add(new SimpleGrantedAuthority(role.getName())); } return new org.springframework.security.core.userdetails.User(user.getUsername(), user.getPassword(), authorities); } } ``` ```java @Controller public class UserController { @PreAuthorize("hasRole('USER')") @GetMapping("/user") public String user() { return "user"; } @PreAuthorize("hasRole('ADMIN')") @GetMapping("/admin") public String admin() { return "admin"; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值