2022-12-13 20:21来源:m.sf1369.com作者:宇宇
目前来说, 没有很好的办法... $_server[\'http_referer\']??假如没有这个来路, 都设置为其它来路即可. 就目前51la cnzz 百度统计, 也没有解决这样问题.!!
举个最简答的例子.
让你同事在他的php项目中做一个 xlogin.php,这个php程序可以用 xlogin.php?u=xxx&p=yyy的形式接收用户名和密码(或者其它信息) 处理成功即允许用户处于登录状态.同时生成一个登录的session
在你的java项目的登录中,用户登录成功后你写个程序去访问你同事的xlogin.php把 u和p传递给他.
即可实现java登录php也登录了.
------------
这是一个简答的思路.安全有问题.你可以根据实际情况,修改思路.比如,xlogin.php限制来源的ip.
不直接传递u和p这样东西.改成一个你们两约定的字串来验证也可以.比如一个进行过md5验证的sessionid
小白不懂题目的意思,难道是伪造CURL来源IP?
不过伪造IP倒也是必须用代理
比如: curl_setopt($curl, CURLOPT_PROXY, );
//获取当前的域名:
echo $_SERVER['SERVER_NAME'];
//获取来源网址,即点击来到本页的上页网址
echo $_SERVER[HTTP_REFERER];
$_SERVER['REQUEST_URI'];//获取当前域名的后缀
$_SERVER['HTTP_HOST'];//获取当前域名
dirname(__FILE__);//获取当前文件的物理路径
dirname(__FILE__)./../;//获取当前文件的上一级物理路径
?>
(新顶级域名top域名O(∩_∩)O)
$p=a/b/c.txt;
echo $a=dirname($p);
basename($p);
结果依次是:a/b、c.txt
$user_agent = $_SERVER['HTTP_USER_AGENT'];
if (strpos($user_agent, 'MicroMessenger') === false) {
// 非微信浏览器禁止浏览
echo HTTP/1.1 401 Unauthorized;
} else {
// 微信浏览器,允许访问
echo MicroMessenger;
// 获取版本号
preg_match('/.*?(MicroMessenger\/([0-9.]+))\s*/', $user_agent, $matches);
echo '<br>Version:'.$matches[2];
}
不用cookie就只能用
Ajax+数据库~
如果要考虑来源,只能通过记录IP了~
FastCGI原理
FastCGI是一个运用于Http Server和动态脚本语言间通信的接口,多数流行的Http Server都支持FastCGI,包括Apache、Nginx和lighttpd等。同时,FastCGI也被许多脚本语言支持,其中就有PHP。
FastCGI接口方式采用C/S结构,可以将HttP服务器和脚本解析服务器分开,同时在脚本解析服务器上启动一个或者多个脚本解析守护进程。当HttP服务器每次遇到动态程序时,可以将其直接交付给FastCGI进程来执行,然后将得到的结果返回给客户端。这种方式可以让HttP服务器专一地处理静态请求或者将动态脚本服务器的结果返回给客户端,这在很大程度上提高了整个应用系统的性能。
Nginx+php-fpm实现原理
Nginx本身不会对PHP进行解析,终端对PHP页面的请求将会被Nginx交给FastCGI进程监听的IP地址及端口,由php-fpm作为动态解析服务器处理,最后将处理结果再返回给nginx。其实,Nginx就是一个反向代理服务器。Nginx通过反向代理功能将动态请求转向后端php-fpm,从而实现对PHP的解析支持,这就是Nginx实现PHP动态解析的原理。
Nginx不支持对外部程序的直接调用或者解析,所有的外部程序(包括PHP)必须通过FastCGI接口来调用。FastCGI接口在Linux下是socket(这个socket可以是文件socket,也可以是ip socket)。为了调用CGI程序,还需要一个FastCGI的wrapper(wrapper可以理解为用于启动另一个程序的程序),这个wrapper绑定在某个固定socket上,如端口或者文件socket。当Nginx将CGI请求发送给这个socket的时候,通过FastCGI接口,wrapper接收到请求,然后派生出一个新的线程,这个线程调用解释器或者外部程序处理脚本并读取返回数据;接着,wrapper再将返回的数据通过FastCGI接口,沿着固定的socket传递给Nginx;最后,Nginx将返回的数据发送给客户端。
Nginx 简单配置
location ~ \.php$ {
root /home/admin/web/nginx/html/;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /home/admin/web/nginx/html/$fastcgi_script_name;
include fastcgi_params;
}
希望对您有所帮助.