Categories


Tags


常见程序搜索关键字转码

个别搜索类的网站因为用户恶意搜索出现误拦截情况,这类网站本身没有非法信息,只是因为把搜索关键字显示在网页中(如下图)

,可以参考下面方法对输出的关键字进行转码

image.png

DEDECMS程序

本文针对Dedecms程序进行搜索转码,其它程序原理类似:对搜索结果的关键字进行转码后输出

一:查看网站编码,访问后台下面会显示,GBK和UTF8两个版本

image.png

二:复制下面代码到 include/extend.func.php 文件尾部(根据您的网站编码复制对应的代码,编辑网页时推荐使用notepad、editplus软件)

UTF-8编码

function CharCodeAt($str)

{

$strr="";

for($i=0;$i<mb_strlen($str,'utf-8');$i++){

$char = mb_substr($str,$i,1, 'UTF-8');

if (mb_check_encoding($char, 'UTF-8'))

{

$ret = mb_convert_encoding($char, 'UTF-32BE', 'UTF-8');

$strr.="&#".hexdec(bin2hex($ret));

}

else

{

return null;

}

}

return $strr;

}

GBK编码

function CharCodeAt($str)

{

$strr="";

for($i=0;$i<mb_strlen($str,'gb2312');$i++){

$char = mb_substr($str,$i,1, 'gb2312');

if (mb_check_encoding($char, 'gb2312'))

{

$ret = mb_convert_encoding($char, 'UTF-32BE', 'gb2312');

$strr.="&#".hexdec(bin2hex($ret));

}

else

{

return null;

}

}

return $strr;

}

三:修改搜索模板文件templets/default/search.htm  【其它模板可能路径会有变化】

找到: {dede:global name='keyword' function='RemoveXSS(@me)'/}

替换成:{dede:global name='keyword' function='CharCodeAt(RemoveXSS(@me))'/}

四:查看搜索页源代码,查看是否生效

image.png

Discuz 程序,示例针对Discuz!X3.4  GBK版本

一、查看网页编码

1.网页右键查看源代码

blob.png

2.查看config/config.php 的$_config['output']['charset']

blob.png

二、根据编码复制上面的CharCodeAt函数,修改 source/function/function_search.php 文件,加到文件尾部,注意在?> 前面

blob.png

三、修改source/module/search/search_forum.php 程序

在129行添加如下两行代码

$keyword = CharCodeAt($keyword);

$modkeyword = CharCodeAt($modkeyword);

blob.png

四、查看搜索页源代码,检查是否生效

blob.png

来源:西部数码


Public @ 2022-08-05 15:44:44

电子商务网站帮助中心的设计思路

近几日在设计帮助中心参加评审过程中遇到的一些问题,帮助中心到底是干什么用的?帮助中心应该帮助用户什么?帮助中心流量大了是否要充分利用起来?帮助中心是否应该增加UGC模块?这篇博文记录一下我对帮助中心的思考和设计过程,希望能对大家有所帮助,如果有不同意见欢迎指出和探讨。#帮助中心到底是干什么用的?就目前各大网站帮助中心的设计帮助中心属于网站中重要的组成部分,但是在UE和UI设计的过程中全部都是弱化设

Public @ 2014-07-08 15:32:36

域名基本类型

域名的基本类型包括顶级域名(Top-level Domain,TLD)和二级域名(Second-level Domain,SLD)。 1. 顶级域名(TLD):顶级域名是域名中最高一级的分类,也是互联网域名系统(Domain Name System,DNS)中的最高级别分类。顶级域名通常分为两类: - 通用顶级域名(Generic Top-level Domain,gTLD):包括常见的后缀如

Public @ 2023-07-22 10:00:25

CMS模板开发应该注意什么?

在进行CMS模板开发时,应注意以下几点: 1. 规范化命名:给模块、组件、样式类等都使用规范化、一致性的命名,以方便其他开发者理解和维护代码。 2. 响应式设计:当前移动设备的普及,需要确保模板在不同设备上都能良好地显示和交互。 3. 可重用性:设计模板时应尽量将模块与页面解耦,使其可以被多个页面共享,提高开发效率。 4. 可定制性:提供一些可配置的选项,以满足用户对模板的个性化需求。

Public @ 2023-07-24 08:50:27

Struts2漏洞预警

1、要求对Struts2应用进行安全扫描,发现并消除系统中的漏洞,确保系统的可靠性和安全性; 2、针对Struts2的XML处理部分定期进行安全审计,预防XML内容未经安全检查乱入系统; 3、加强输入参数检查,确保输入参数的正确性能和安全性; 4、加强拦截过滤,有效阻止XSS攻击、SQL注入攻击等; 5、避免使用Struts2处理未经安全检查的输入参数,防止受到系统漏洞或攻击; 6、

Public @ 2023-02-28 14:48:23

更多您感兴趣的搜索

0.408554s