`
zds420
  • 浏览: 203643 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

COOKIE IP地址限制投票次数

 
阅读更多

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page import="com.saas.query.baseQueryConf.JDBCExceute" %>
<%! 
public String getIpAddr(HttpServletRequest request) { 
    String ip = request.getHeader("x-forwarded-for"); 
    if(ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { 
        ip = request.getHeader("Proxy-Client-IP"); 
    } 
    if(ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { 
        ip = request.getHeader("WL-Proxy-Client-IP"); 
    } 
    if(ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { 
        ip = request.getRemoteAddr(); 
    } 
    return ip; 
} 

public String getCookieIPAddress(HttpServletRequest request,HttpServletResponse response,String ip_address) {
	Cookie[] cookies = request.getCookies();
	String cookievalue ="";
	if(null!=cookies && cookies.length!=0) {
		for(int i=0;i<cookies.length;i++) {
			Cookie cookie = cookies[i];
			if(cookie.getName().equals("cookie_ip_"+ip_address)) {
				String value= cookie.getValue();
				String[] value_array=value.split("\\|");
				int time= Integer.parseInt(value_array[1])+1;
				cookievalue = value_array[0]+"|"+time;//取出原来cookie中的信息,在后面追加信息    
                Cookie c = new Cookie("cookie_ip_"+ip_address,cookievalue);  //编码后添加都cookie    
                c.setMaxAge(60 * 60);    
                c.setPath("/");    
                response.addCookie(c); 
			}
			else {
				Cookie c = new Cookie("cookie_ip_"+ip_address,ip_address+"|1");
				c.setMaxAge(24*60*60);
				c.setPath("/");
				response.addCookie(c);
			}
			System.out.println(cookievalue);
		}
	}
	return cookievalue;
}
%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

String article_id = request.getParameter("article_id")!=null ? request.getParameter("article_id").toString() : "";
String ip_address = getIpAddr(request);

String vote_stats="";

String cookie_ip = getCookieIPAddress(request,response,ip_address);

String[] cookie_ip_array = cookie_ip.split("\\|");

System.out.println(cookie_ip_array[1]);
if(!"".equals(cookie_ip_array[1].toString().trim()) && Integer.parseInt(cookie_ip_array[1])>=20) {
	vote_stats="每个IP地址每天限投20票";
}
else {
	JDBCExceute jdbc = new JDBCExceute();
	jdbc.CRUD("update ith_article set rsrv_str4=rsrv_str4+1 where article_id='"+article_id+"'");
	vote_stats="投票成功";
}
%>
<%=vote_stats%>
 
分享到:
评论
2 楼 zds420 2012-09-21  
Zhang987526341 写道
求lz 详细说说,我复制您的代码后,要怎么改啊 。。初学者,求详细解释

抱歉,最近繁忙,未能及时看到留言,我这是把简单的代码提出来了,还有数据库表没贴出来,主要就是根据IP地址限制投票,还要新建一个IP地址库。
1 楼 Zhang987526341 2012-08-27  
求lz 详细说说,我复制您的代码后,要怎么改啊 。。初学者,求详细解释

相关推荐

    关于网络投票限制及突破方法探讨

    首先,最常见的限制是基于IP地址的投票次数限制。服务器会记录投票者的IP地址,限制每个IP每天只能投一票。为突破这种限制,可以利用工具的代理服务器功能。《网页自动操作通用工具》支持批量自动更换IP,通过代理...

    ASP简单投票系统区分IP自动判断次数

    5. 自动判断次数:为了自动判断次数,我们可以设置一个计数器或者标记来跟踪每个IP的投票次数。如果超过预设的限制(比如,每个IP只能投一次),则阻止进一步的投票。 6. 错误处理和测试:描述中提到该系统经过多次...

    jsp网上投票系统,可禁止同一IP重复投票

    - 系统通过用户的IP地址来限制重复投票,这是常见的防刷票手段。IP地址可以通过`request`对象的`getRemoteAddr()`方法获取。 - 对于同一台电脑的识别,可能涉及到浏览器的Cookie或者JavaScript的User Agent,但这...

    PHP设计在线投票系统.pdf

    5. 限制投票次数的实现:限制投票次数可以使用 PHP 语言来实现,例如,使用会话 cookie 或者 IP 地址来限制投票次数。 6. 3D 饼形图在分析投票结果中的应用:3D 饼形图可以用来比较直观地展示投票结果,jpgraph 类库...

    PHP实现的限制IP投票程序IP来源分析

    - 如果用户需要登录才能投票,可以基于用户账号而非IP地址来限制投票次数,这样即使同一IP下有多个用户,也能保证每个用户公平投票。 - 记录投票日志,以便追踪异常行为,一旦发现有大量重复投票,可以进行调查并...

    asp.net 校园歌手投票

    1. **IP限制**:记录每个IP地址的投票次数,超过预设阈值则阻止进一步投票。 2. **Cookie验证**:通过设置Cookie来跟踪用户已投票信息,防止重复投票。 3. **验证码**:使用CAPTCHA验证码技术,要求用户输入图片中的...

    简单的投票系统 asp+access

    之后,如果用户再次尝试投票,服务器会检查该cookie是否存在,如果存在,则拒绝投票,以此限制同一IP地址多次投票。 投票系统的基本流程如下: 1. 用户访问投票页面。 2. ASP脚本验证用户是否已经投票,检查方法是...

    asp.net 投票功能

    另外,为了防止恶意刷票,还可以设置IP限制,比如记录最近投票的IP地址,并设定每个IP的投票频率上限。 最后,为了保证用户友好性和可用性,应考虑添加错误处理和验证机制。例如,验证用户输入,确保投票选项的有效...

    投票系统

    涉及到的IT知识点包括:PHP编程、数据库设计(如MySQL)、HTTP服务器配置(`.htaccess`)、用户认证与授权、前端界面设计(HTML/CSS)、Web安全措施(如防止SQL注入、限制投票次数)以及性能优化。开发者需要具备...

    图文投票系统 asp

    ASP可以实现IP地址检查、Cookie验证等方式限制投票次数。 5. **图片处理**:图文投票系统需要处理上传的图片。ASP可以使用内置的ADO对象读取、处理图片文件,或者调用服务器端的图像处理库。 6. **错误处理和日志...

    php制作小型投票系统

    5. **安全措施**:为了防止恶意刷票,我们需要实施一些安全措施,如限制每个IP地址的投票次数,或者通过验证码验证用户的真实性。 现在,让我们详细讨论实现这些功能的步骤: 1. **创建数据库结构**:在MySQL中...

    评选投票源代码

    同时,需要有防止作弊的机制,例如限制同一IP的投票次数或使用验证码。 3. 数据存储:保存候选人信息、投票记录以及用户信息。这通常需要一个数据库系统,如MySQL或MongoDB,来存储和管理这些数据。 4. 后台管理:...

    网站系统中在线投票功能源码

    - **防止作弊**:通过IP地址、cookie或其他用户唯一标识来限制每个用户只能投票一次。 4. **前端交互**: - 使用JavaScript或jQuery实现动态效果,如选中选项后的即时反馈,投票后的提示信息等。 - 与后端API...

    投票系统C#

    例如,系统可能会记录每个IP地址的投票次数,超过限制则阻止进一步投票;使用cookie来识别已投票用户;或者在投票时显示图形验证码,确保投票是由人类操作而非自动脚本完成。 4. **数据库设计**:投票系统通常需要...

    php简易网上投票系统

    开发者可能采用了IP地址验证、cookie记录或session管理等方式来限制用户投票次数。同时,对用户输入进行过滤和验证,防止SQL注入等安全威胁。 5. **前端设计**:投票界面应简洁明了,易于用户操作。HTML和CSS用于...

    2021-2022收藏资料网站投票防刷票验证码分析和实践.docx

    - 通过限制每个IP地址的投票次数,IP限制一度被视为有效的防护手段。但随着拨号连接、代理服务器和“肉鸡”(被控制的远程计算机)的使用,这种方法的局限性日益显现。特别是利用大量肉鸡,可以轻松突破IP限制。 3...

    PHP投票程序

    例如,限制未注册用户投票次数,或者只有登录用户才能参与投票。 9. 设计响应式布局:为了适应各种设备,投票界面应采用响应式设计,确保在手机、平板和桌面电脑上都能良好显示。 10. 错误处理与日志记录:良好的...

    Asp.net2.0多功能投票系统源码

    同时,为了防止IP欺骗,还可以通过记录IP地址进行额外的投票限制。 此外,投票系统还允许设置当前投票,这意味着可以有多个投票同时进行,用户可以根据需要选择参与哪个投票。这涉及到前端界面的设计,需要清晰地...

    商业编程-源码-雪晖投票系统 xhvote v3.1.0716 UTF-8 PHP版.zip

    5. **投票逻辑与防作弊机制**:XHVote 可能会实现一些防止投票欺诈的机制,比如限制每个IP地址的投票次数、设置验证码或者通过cookie追踪用户投票行为。 6. **前端界面设计**:系统应提供用户友好的界面,使投票...

Global site tag (gtag.js) - Google Analytics