如何防止网站垃圾留言评论的肆略(zhuan)

本文探讨了SEO专家滥用垃圾留言的问题,并提供了几种有效防御策略,包括判断信息来源、使用验证码及限制用户留言频率等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

可能很多自称是SEO高手的“专家”们都有一个同样的“法宝”,那就是疯狂地在其他网站上留下大量的垃圾留言,垃圾评论,以便留下他们的链接。或许这在很久以前可能有用,随着SE的反SPAM的技术不断的升级,现在再这样做简直是自找死路,无疑是给SE一个惩罚你的理由。

 

    然而,这些高手们依然不知疲倦乐在其中,或机器自动留言,或人肉留言,总之,只要是可以留下一个链接的地方都留下了他们坚强的身影,他们才不管你的网站是什么类型的,走过路过都要进去评论一下。鉴于垃圾猛于虎的严峻形势, 飘易博客甚至不得不将评论设置为需要审核才能显示。

 

    当然,我们也不是完全反对留言评论,WEB2.0需要网站和用户的互动,但要留言至少也要看下别人的文章,有感而发嘛,这是非常正常的交流沟通方式,我们非常欢迎这样的留言和评论。

 

    当然,我们需要反击,针对机器每秒几十几百的信息发布量,我们也要从技术手段上屏蔽它们。如何具体操作呢?flymorn提供几个可行有效的方法。

 

    1、判断该发布信息是否有可靠的来路。只要是自然人发布的,那么他一定是通过我们提供给用户的提交页过来的,一定有一个来路;如果是机器发布的,就不会有来路信息。

 

'判断来路,禁止外部提交
dim server_v1,server_v2
server_v1=Cstr(Request.ServerVariables("HTTP_REFERER"))
server_v2=Cstr(Request.ServerVariables("SERVER_NAME"))
if server_v1="" or instr(server_v1,"/add.asp")<=0 or mid(server_v1,8,len(server_v2))<>server_v2 then
response.write "<SCRIPT language=JavaScript>alert('来源非法,禁止外部提交!');"
response.write "this.location.href='vbscript:history.back()';</SCRIPT>"
response.end
end if

 

    注意,上面的/add.asp就是提交页面来源页。当然,机器也可以伪造来路,这就要结合以下方式一起对付了。

 

    2、验证码。验证码一直是对付机器垃圾留言的一个可行的方法。不同的验证码有不同的对付机器留言的能力,越复杂的验证码,机器越难破解。这需要在考虑用户的感受和对付机器之间选择一个平衡点。关于验证码的使用方法,我就不多说了,谷歌、百度里搜索下就会出现很多介绍。

 

    3、判断来源提交的时间。如果在提交页停留的时间太短,比如20秒,一般只要是个人,他打字的时间都不必这个少。举例说明,在用户打开页面(如add.asp)的时候,我们记下这个时间,在form提交表单里增加一个隐藏对象,如:
<input name="intime1" type="hidden" value="<%=Now()%>">

    然后,当用户写好留言评论后提交到具体处理页面(如addok.asp)的时候,我们获取当前时间,和add.asp里的这个intime1时间比较,如果这个时间差小于设定的时间,如20秒,则禁止留言,判断为机器。代码可这样写:
If DateDiff("s",request.form("intime1"), Now()) < 20 then
response.write "<SCRIPT language=JavaScript>alert('您的留言速度太快了吧,禁止留言!');"
response.write "this.location.href='vbscript:history.back()';</SCRIPT>"
response.end
end if

 

    通过以上三种方法可以屏蔽掉绝大部分的机器垃圾留言评论,如果还有大量的留言的话,那多半是人肉留言了。但是,我们又如何对付人肉留言呢?flymorn也提供方法对付。

 

    方法很简单,就是通过记录用户的cookies以及IP来限制同一用户发表留言的数量。比如一天24小时内,只允许同一用户发表信息5条。我们可以通过以下方法实现。

 

<%'当用户每提交一次
if request.cookies("postnum")="" then
response.cookies("postnum")=1
response.cookies("postnum").expires=DateAdd("h", 24, Now()) 
else
response.cookies("postnum")=request.cookies("postnum")+1
end if
if request.cookies("postnum") > 5 then
response.write "<SCRIPT language=JavaScript>alert('今天留言次数超过限制,禁止留言!');"
response.write "this.location.href='vbscript:history.back()';</SCRIPT>"
response.end
end if 
%>

 

    通过以上的限制,人工发帖也得到了一定的限制。上面的方法是基于cookies判断,当然用户可以通过浏览器清空COOKIES,但这样增加了他们发垃圾帖子的难度,提高了门槛。我们还可以继续判断发布者的IP,通过同一个IP下发帖限制数量来达到我们的目的。在此,就不再扩展,大家可以自己设计如何判断IP来限制发帖的方法。如果您对本文讨论的主题有看法或建议,欢迎留下评论,以便我们一起探讨。

转载于:https://www.cnblogs.com/zhdonghu/archive/2010/09/17/1829363.html

<think>好的,我现在要解决用户的问题:“java Long zhuan Interger”。看起来用户可能想了解如何将Java中的Long类型转换为Integer类型,但可能存在拼写错误。首先,我需要确认用户的需求是否正确,即是否真的是将Long转为Integer,而不是其他类型,比如int。 接下来,我应该回顾Java中基本数据类型和包装类的转换方法。Long和Integer都是包装类,分别对应基本类型long和int。由于它们都是Number的子类,但直接转换可能会遇到问题,因为它们之间没有继承关系,所以需要显式转换。 可能的转换步骤包括:首先从Long对象中获取long值,然后将其转换为int,再使用Integer的valueOf方法或者直接构造Integer对象。但需要注意,如果Long的值超出了Integer的范围(-2^31到2^31-1),转换会导致数据丢失或错误,因此需要检查范围。 另外,还要考虑自动拆箱和装箱的问题,以及Java 8之后的一些方法,比如Math.toIntExact,这个方法在转换时如果超出范围会抛出异常,增加安全性。 还需要提醒用户,从Java 9开始,Integer的构造函数被标记为过时,推荐使用静态工厂方法valueOf,以提高性能,因为会利用缓存。 可能的示例代码包括:使用intValue()方法,或者显式转换,以及处理可能的异常情况。同时,应该比较不同方法的优缺点,比如直接转换和检查范围的方法。 最后,总结步骤和注意事项,确保用户理解转换过程中可能的风险和最佳实践。</think>在Java中,将`Long`类型转换为`Integer`类型需要分步处理。以下是详细的步骤和注意事项: --- ### 一、基本转换步骤 1. **获取`Long`的基本类型值** 通过`longValue()`方法提取`Long`对象的原始`long`类型值: ```java Long longObj = 12345L; long primitiveLong = longObj.longValue(); ``` 2. **将`long`强制转换为`int`** 通过强制类型转换将`long`转为`int`: ```java int primitiveInt = (int) primitiveLong; ``` 3. **将`int`封装为`Integer`** 使用`Integer.valueOf()`或自动装箱生成`Integer`对象: ```java Integer integerObj = Integer.valueOf(primitiveInt); // 或直接自动装箱 Integer integerObj2 = primitiveInt; ``` --- ### 二、完整代码示例 ```java Long longValue = 12345L; // 方法1:分步显式转换 int intValue = longValue.intValue(); // 直接调用intValue()方法 Integer integerValue1 = Integer.valueOf(intValue); // 方法2:一步完成(自动拆箱+强制转换) Integer integerValue2 = (int) (long) longValue; // 方法3:使用Java 8的Math.toIntExact()(推荐) try { Integer integerValue3 = Math.toIntExact(longValue); } catch (ArithmeticException e) { System.out.println("超出Integer范围!"); } ``` --- ### 三、关键注意事项 1. **范围检查** `Integer`的范围是$-2^{31}$到$2^{31}-1$(即`-2147483648`到`2147483647`)。 如果`Long`值超出此范围,强制转换会导致数据错误: ```java Long largeLong = 3000000000L; // 超出Integer最大值 int badValue = (int) largeLong.longValue(); // 结果为-1294967296(错误) ``` 2. **推荐使用`Math.toIntExact()`** Java 8新增的`Math.toIntExact()`方法会在转换时检查范围,若溢出则抛出`ArithmeticException`: ```java try { int safeValue = Math.toIntExact(largeLong); } catch (ArithmeticException e) { System.out.println("转换失败:" + e.getMessage()); } ``` 3. **避免直接调用构造函数** Java 9后,`new Integer(int)`已过时,建议使用`Integer.valueOf(int)`,该方法会复用缓存对象(范围`-128`到`127`),提高性能。 --- ### 四、总结 - **安全转换流程**: $$ \text{Long对象} \xrightarrow{\text{.longValue()}} \text{long} \xrightarrow{\text{强制转换}} \text{int} \xrightarrow{\text{Integer.valueOf()}} \text{Integer对象} $$ - **优先选择范围检查方法**(如`Math.toIntExact()`),避免数据丢失。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值