文件目录:
ipLocation
-----qqwry
----------QQWry.Dat
-----ipCity.class.php
ipCity.class.php文件代码:
class ipCity {
/**
* 根据ip地址获取对应所在城市
* @param type $userip 用户IP地址
* @return string
*/
public function getCity( $userip, $dat_path = '' ) {
//IP数据库路径,这里用的是QQ IP数据库 20110405 纯真版
empty( $dat_path ) && $dat_path = FCPATH . 'plugin/ipLocation/qqwry/QQWry.Dat';
//判断IP地址是否有效
if ( preg_match( "/^([0-9]{1,3}.){3}[0-9]{1,3}$/", $userip ) == 0 ) {
return 'IP Address Invalid';
}
//打开IP数据库
if ( !$fd = @fopen( $dat_path, 'rb' ) ) {
return 'IP data file not exists or access denied';
}
//explode函数分解IP地址,运算得出整数形结果
$userip = explode( '.', $userip );
$useripNum = $userip[0] * 16777216 $userip[1] * 65536 $userip[2] * 256 $userip[3];
//获取IP地址索引开始和结束位置
$DataBegin = fread( $fd, 4 );
$DataEnd = fread( $fd, 4 );
$useripbegin = implode( '', unpack( 'L', $DataBegin ) );
if ( $useripbegin $useripbegin = pow( 2, 32 );
$useripend = implode( '', unpack( 'L', $DataEnd ) );
if ( $useripend $useripend = pow( 2, 32 );
$useripAllNum = ($useripend - $useripbegin) / 7 1;
$BeginNum = 0;
$EndNum = $useripAllNum;
//使用二分查找法从索引记录中搜索匹配的IP地址记录
while ( $userip1num > $useripNum || $userip2num $Middle = intval( ($EndNum $BeginNum) / 2 );
//偏移指针到索引位置读取4个字节
fseek( $fd, $useripbegin 7 * $Middle );
$useripData1 = fread( $fd, 4 );
if ( strlen( $useripData1 ) fclose( $fd );
return 'File Error';
}
//提取出来的数据转换成长整形,如果数据是负数则加上2的32次幂
$userip1num = implode( '', unpack( 'L', $useripData1 ) );
if ( $userip1num $userip1num = pow( 2, 32 );
//提取的长整型数大于我们IP地址则修改结束位置进行下一次循环
if ( $userip1num > $useripNum ) {
$EndNum = $Middle;
continue;
}
//取完上一个索引后取下一个索引
$DataSeek = fread( $fd, 3 );
if ( strlen( $DataSeek ) fclose( $fd );
return 'File Error';
}
$DataSeek = implode( '', unpack( 'L', $DataSeek . chr( 0 ) ) );
fseek( $fd, $DataSeek );
$useripData2 = fread( $fd, 4 );
if ( strlen( $useripData2 ) fclose( $fd );
return 'File Error';
}
$userip2num = implode( '', unpack( 'L', $useripData2 ) );
if ( $userip2num $userip2num = pow( 2, 32 );
//找不到IP地址对应城市
if ( $userip2num if ( $Middle == $BeginNum ) {
fclose( $fd );
return 'No Data';
}
$BeginNum = $Middle;
}
}
$useripFlag = fread( $fd, 1 );
if ( $useripFlag == chr( 1 ) ) {
$useripSeek = fread( $fd, 3 );
if ( strlen( $useripSeek ) fclose( $fd );
return 'System Error';
}
$useripSeek = implode( '', unpack( 'L', $useripSeek . chr( 0 ) ) );
fseek( $fd, $useripSeek );
$useripFlag = fread( $fd, 1 );
}
if ( $useripFlag == chr( 2 ) ) {
$AddrSeek = fread( $fd, 3 );
if ( strlen( $AddrSeek ) fclose( $fd );
return 'System Error';
}
$useripFlag = fread( $fd, 1 );
if ( $useripFlag == chr( 2 ) ) {
$AddrSeek2 = fread( $fd, 3 );
if ( strlen( $AddrSeek2 ) fclose( $fd );
return '系统错误';
}
$AddrSeek2 = implode( '', unpack( 'L', $AddrSeek2 . chr( 0 ) ) );
fseek( $fd, $AddrSeek2 );
} else {
fseek( $fd, -1, SEEK_CUR );
}
while ( ($ char = fread( $fd, 1 )) != chr( 0 ) )
$useripAddr2 .= $char;
$AddrSeek = implode( '', unpack( 'L', $AddrSeek . chr( 0 ) ) );
fseek( $fd, $AddrSeek );
while ( ($char = fread( $fd, 1 )) != chr( 0 ) )
$useripAddr1 .= $char;
} else {
fseek( $fd, -1, SEEK_CUR );
while (($char = fread( $fd, 1 )) != chr( 0 ) )
$user ip地址1。 = $char;
$useripFlag = fread( $fd, 1 );
if ( $useripFlag == chr( 2 ) ) {
$AddrSeek2 = fread( $fd, 3 );
if ( strlen( $AddrSeek2 ) fclose( $fd );
return '系统错误';
}
$AddrSeek2 = implode( '', unpack( 'L', $AddrSeek2 . chr( 0 ) ) );
fseek( $fd, $AddrSeek2 );
} else {
fseek( $fd, -1, SEEK_CUR );
}
while ( ($char = fread( $ fd, 1 )) != chr( 0 ) ) {
$useripAddr2 .= $char;
}
}
fclose( $fd );
//返回IP地址的对应值城市结果
if ( preg_match( '/http/i', $useripAddr2 ) ) {
$useripAddr2 = '';
}
$useripaddr = "$useripAddr1 $useripAddr2";
$useripaddr = preg_replace( '/CZ88.Net/is', '', $useripaddr );
$useripaddr = preg_replace( '/^s* /is', '', $useripaddr );
$useripaddr = preg_replace( '/s*$/is', '', $useripaddr );
if ( preg_match( '/http/i', $ useripaddr ) || $useripaddr == '' ) {
$useripaddr = '无数据';
} elseif ( !$this->is_utf8( $useripaddr ) ) {
$useripaddr = iconv( 'GBK', 'UTF-8', $useripaddr );
}
return $useripaddr;
}
/**
* 判断是否我utf-8编码的字符串
* @param type $string
* @return boolean
*/
private function is_utf8( $string ) {
if ( preg_match( "/^([" . chr( 228 ) . "-" . chr( 233 ) . “]{1}[”。“-”。“]{1}[”。“-”。“]{1}) {1}/", $string ) == true || preg_match( "/([" . chr( 228 ) . "-" . chr( 233 ) . "]{1}[" . chr( 128 ) . " -" . chr( 191 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1}){1}$/", $string ) == true | | preg_match( "/([" . chr( 228 ) . "-" . chr( 233 ) . "]{1}[" . chr( 128 ) . "-" . chr( 191 ) . "]{1} [" . chr( 128 ) . "-" . chr( 191 ) . "]{1}){2,}/", $string ) == true ) {
return true;
} else {
返回 false;
}
}
}
QQWry.Dat文件下载地址:http://xiazai.php.net/201311/yuanma/qqwry.dat(php.net).zip
使用演示:
包含 FCPATH 。 'plugin/ipLocation/ipCity.class.php';
$city = new ipCity();
$addr = $city->getCity( '172.0.0.1' );
echo $addr; // echo 本地地址

绝对会话超时从会话创建时开始计时,闲置会话超时则从用户无操作时开始计时。绝对会话超时适用于需要严格控制会话生命周期的场景,如金融应用;闲置会话超时适合希望用户长时间保持会话活跃的应用,如社交媒体。

服务器会话失效可以通过以下步骤解决:1.检查服务器配置,确保会话设置正确。2.验证客户端cookies,确认浏览器支持并正确发送。3.检查会话存储服务,如Redis,确保其正常运行。4.审查应用代码,确保会话逻辑正确。通过这些步骤,可以有效诊断和修复会话问题,提升用户体验。

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

设置httponly标志对会话cookie至关重要,因为它能有效防止XSS攻击,保护用户会话信息。具体来说,1)httponly标志阻止JavaScript访问cookie,2)在PHP和Flask中可以通过setcookie和make_response设置该标志,3)尽管不能防范所有攻击,但应作为整体安全策略的一部分。

phpsessions solvathepromblymaintainingStateAcrossMultipleHttpRequestsbyStoringDataTaNthEserVerAndAssociatingItwithaIniquesestionId.1)他们储存了AtoredAtaserver side,通常是Infilesordatabases,InseasessessionIdStoreDistordStoredStoredStoredStoredStoredStoredStoreDoreToreTeReTrestaa.2)

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考虑使用AttActAcks.s.s.4)

会话再生是指在用户进行敏感操作时生成新会话ID并使旧ID失效,以防会话固定攻击。实现步骤包括:1.检测敏感操作,2.生成新会话ID,3.销毁旧会话ID,4.更新用户端会话信息。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Atom编辑器mac版下载
最流行的的开源编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3汉化版
中文版,非常好用

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。