<%@ 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%>
分享到:
相关推荐
首先,最常见的限制是基于IP地址的投票次数限制。服务器会记录投票者的IP地址,限制每个IP每天只能投一票。为突破这种限制,可以利用工具的代理服务器功能。《网页自动操作通用工具》支持批量自动更换IP,通过代理...
5. 自动判断次数:为了自动判断次数,我们可以设置一个计数器或者标记来跟踪每个IP的投票次数。如果超过预设的限制(比如,每个IP只能投一次),则阻止进一步的投票。 6. 错误处理和测试:描述中提到该系统经过多次...
- 系统通过用户的IP地址来限制重复投票,这是常见的防刷票手段。IP地址可以通过`request`对象的`getRemoteAddr()`方法获取。 - 对于同一台电脑的识别,可能涉及到浏览器的Cookie或者JavaScript的User Agent,但这...
5. 限制投票次数的实现:限制投票次数可以使用 PHP 语言来实现,例如,使用会话 cookie 或者 IP 地址来限制投票次数。 6. 3D 饼形图在分析投票结果中的应用:3D 饼形图可以用来比较直观地展示投票结果,jpgraph 类库...
- 如果用户需要登录才能投票,可以基于用户账号而非IP地址来限制投票次数,这样即使同一IP下有多个用户,也能保证每个用户公平投票。 - 记录投票日志,以便追踪异常行为,一旦发现有大量重复投票,可以进行调查并...
1. **IP限制**:记录每个IP地址的投票次数,超过预设阈值则阻止进一步投票。 2. **Cookie验证**:通过设置Cookie来跟踪用户已投票信息,防止重复投票。 3. **验证码**:使用CAPTCHA验证码技术,要求用户输入图片中的...
之后,如果用户再次尝试投票,服务器会检查该cookie是否存在,如果存在,则拒绝投票,以此限制同一IP地址多次投票。 投票系统的基本流程如下: 1. 用户访问投票页面。 2. ASP脚本验证用户是否已经投票,检查方法是...
另外,为了防止恶意刷票,还可以设置IP限制,比如记录最近投票的IP地址,并设定每个IP的投票频率上限。 最后,为了保证用户友好性和可用性,应考虑添加错误处理和验证机制。例如,验证用户输入,确保投票选项的有效...
涉及到的IT知识点包括:PHP编程、数据库设计(如MySQL)、HTTP服务器配置(`.htaccess`)、用户认证与授权、前端界面设计(HTML/CSS)、Web安全措施(如防止SQL注入、限制投票次数)以及性能优化。开发者需要具备...
ASP可以实现IP地址检查、Cookie验证等方式限制投票次数。 5. **图片处理**:图文投票系统需要处理上传的图片。ASP可以使用内置的ADO对象读取、处理图片文件,或者调用服务器端的图像处理库。 6. **错误处理和日志...
5. **安全措施**:为了防止恶意刷票,我们需要实施一些安全措施,如限制每个IP地址的投票次数,或者通过验证码验证用户的真实性。 现在,让我们详细讨论实现这些功能的步骤: 1. **创建数据库结构**:在MySQL中...
同时,需要有防止作弊的机制,例如限制同一IP的投票次数或使用验证码。 3. 数据存储:保存候选人信息、投票记录以及用户信息。这通常需要一个数据库系统,如MySQL或MongoDB,来存储和管理这些数据。 4. 后台管理:...
- **防止作弊**:通过IP地址、cookie或其他用户唯一标识来限制每个用户只能投票一次。 4. **前端交互**: - 使用JavaScript或jQuery实现动态效果,如选中选项后的即时反馈,投票后的提示信息等。 - 与后端API...
例如,系统可能会记录每个IP地址的投票次数,超过限制则阻止进一步投票;使用cookie来识别已投票用户;或者在投票时显示图形验证码,确保投票是由人类操作而非自动脚本完成。 4. **数据库设计**:投票系统通常需要...
开发者可能采用了IP地址验证、cookie记录或session管理等方式来限制用户投票次数。同时,对用户输入进行过滤和验证,防止SQL注入等安全威胁。 5. **前端设计**:投票界面应简洁明了,易于用户操作。HTML和CSS用于...
- 通过限制每个IP地址的投票次数,IP限制一度被视为有效的防护手段。但随着拨号连接、代理服务器和“肉鸡”(被控制的远程计算机)的使用,这种方法的局限性日益显现。特别是利用大量肉鸡,可以轻松突破IP限制。 3...
例如,限制未注册用户投票次数,或者只有登录用户才能参与投票。 9. 设计响应式布局:为了适应各种设备,投票界面应采用响应式设计,确保在手机、平板和桌面电脑上都能良好显示。 10. 错误处理与日志记录:良好的...
同时,为了防止IP欺骗,还可以通过记录IP地址进行额外的投票限制。 此外,投票系统还允许设置当前投票,这意味着可以有多个投票同时进行,用户可以根据需要选择参与哪个投票。这涉及到前端界面的设计,需要清晰地...
5. **投票逻辑与防作弊机制**:XHVote 可能会实现一些防止投票欺诈的机制,比如限制每个IP地址的投票次数、设置验证码或者通过cookie追踪用户投票行为。 6. **前端界面设计**:系统应提供用户友好的界面,使投票...