Jcaptcha集群环境验证失败解决办法

本文介绍了一种在分布式环境中,通过重写CaptchaStore并将验证码信息存储在memcached或redis缓存中的方法,解决了前端从一台服务器获取验证码,后端在另一台服务器验证的问题。通过实现自定义的MyCaptchaStore类,可以确保验证码信息在集群环境下的一致性和可用性。

问题描述:
线上集群环境,前端可能从A服务器取得验证码,而验证是到B服务器
默认的hashmap store是保存在单个Jvm内存中的,这样验证就会有问题
 

解决办法:

重写CaptchaStore,把信息存在缓存中(memcached或redis)

1.重写 MyCaptchaStore 实现 CaptchaStore

public class MyCaptchaStore implements CaptchaStore {

    @Autowired
	private MemcachedService memcachedService;

    @Override
    public boolean hasCaptcha(String id) {
        CaptchaAndLocale captcha = (CaptchaAndLocale) memcachedService.get(id);
        return captcha == null ? false : true;
    }

    @Override
    public void storeCaptcha(String id, Captcha captcha) throws CaptchaServiceException {
        try {
        	memcachedService.add(id,new CaptchaAndLocale(captcha));
        } catch (Exception e) {
            throw new CaptchaServiceException(e);
        }
    }

  
    @Override
    public void storeCaptcha(String id, Captcha captcha, Locale locale) throws CaptchaServiceException {
        try {
        	memcachedService.add(id,new CaptchaAndLocale(captcha,locale));
        } catch (Exception e) {
            throw new CaptchaServiceException(e);
        }

    }

  

    @Override
    public boolean removeCaptcha(String id) {
    	memcachedService.remove(id);
        return true;
    }

    @Override
    public Captcha getCaptcha(String id) throws CaptchaServiceException {
        CaptchaAndLocale captchaAndLocale = (CaptchaAndLocale) memcachedService.get(id);
        return captchaAndLocale != null ? (captchaAndLocale.getCaptcha()) : null;
    }

  

    @Override
    public Locale getLocale(String id) throws CaptchaServiceException {
        CaptchaAndLocale captchaAndLocale = (CaptchaAndLocale) memcachedService.get(id);
        return captchaAndLocale != null ? (captchaAndLocale.getLocale()) : null;
    }

  
    @Override
    public int getSize() {
        return 0;
    }

  
    @Override
    public Collection getKeys() {
        return null;
    }

  
    @Override
    public void empty() {
    	
    }

    @Override
    public void initAndStart() {

    }


    @Override
    public void cleanAndShutdown() {

    }

}

2.配置spring.xml,添加

<!-- 验证码配置 -->
	<bean id="captchaService"
		class="com.octo.captcha.service.multitype.GenericManageableCaptchaService">
		 <constructor-arg type="com.octo.captcha.service.captchastore.CaptchaStore" index="0">	
	        <ref bean="myCaptchaStore"/>	
	    </constructor-arg>
		
		<constructor-arg index="1" ref="imageEngine" />
		<constructor-arg type="int" index="2" value="180" />
		<constructor-arg type="int" index="3" value="100000" />
		<constructor-arg type="int" index="4" value="75000" />
	</bean>


    <bean id="myCaptchaStore" class="com.xxxx.internal.MyCaptchaStore"/>

参考文章:http://zhanshenny.iteye.com/blog/2098779

 

### Hadoop集群搭建常见问题及解决方案 在搭建Hadoop集群的过程中,可能会遇到多种问题。以下是一些常见的问题及其解决办法: #### 1. 集群ID不匹配 当重复初始化Hadoop集群时,可能会导致`DataNode`无法启动。原因是`NameNode`重新生成了集群ID,而`DataNode`仍使用旧的集群ID[^3]。 - **解决办法1**:修改`data/name/`路径下的`version`文件中的集群ID为旧的集群ID。然而,这种方法可能仍然会报错。 - **推荐解决办法2**:删除`hadoop`目录中的`data`和`logs`文件夹,然后重新格式化`NameNode`并重启集群。 #### 2. SSH免密登录配置失败 在配置SSH免密登录时,可能会遇到`Permission denied (publickey,password)`的问题[^3]。 - **原因**:可能是私钥文件权限设置错误或公钥未正确添加到目标机器的`~/.ssh/authorized_keys`文件中。 - **解决办法**: - 确保私钥文件权限为600:`chmod 600 ~/.ssh/id_rsa` - 确保公钥已正确添加到目标机器的`~/.ssh/authorized_keys`文件中。 - 测试免密登录是否成功:`ssh <目标主机IP>` #### 3. Java环境变量未正确配置 如果Java环境变量未正确配置,Hadoop将无法正常运行[^2]。 - **解决办法**: - 检查`/etc/profile`或`~/.bashrc`文件中是否正确设置了`JAVA_HOME`环境变量。 - 确保`PATH`中包含`$JAVA_HOME/bin`。 - 执行`source /etc/profile`以使配置生效[^1]。 #### 4. 配置文件错误 Hadoop的核心配置文件(如`core-site.xml`、`hdfs-site.xml`、`mapred-site.xml`、`yarn-site.xml`)中的参数设置错误可能导致集群无法正常启动[^2]。 - **解决办法**: - 检查所有配置文件是否按照官方文档正确设置。 - 使用`tail -200 <日志文件>`查看具体的错误信息,并根据提示修正配置。 #### 5. 主机名与IP映射问题 如果`/etc/hosts`文件中未正确配置主机名与IP的映射关系,可能会导致节点间通信失败- **解决办法**: - 在所有节点的`/etc/hosts`文件中添加所有节点的IP和主机名映射。 - 确保每个节点都能通过主机名相互访问。 #### 6. 日志文件分析 当Hadoop集群出现问题时,可以通过分析日志文件定位问题[^3]。 - **解决办法**: - 进入Hadoop的日志目录(通常为`logs`)。 - 使用`tail -200 <日志文件>`查看最近的日志信息。 - 根据日志中的错误提示进行排查。 ```bash # 示例:查看NameNode日志 tail -200 logs/hadoop-hadoop-namenode-<hostname>.log ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值