PHP模拟登陆MSN并获得用户信息
一个可以获取msn上用户信息的代码
<font face="NSimsun"><?php </font></font>
/*
* bkJia中文网,整体提供,测试通过
* www.bkJia.com
*/<font face="NSimsun"><br>
$msn = new myMSN(php100@2cto.com, "123");<br>
// MSNv9<br>
class myMSN {<br>
private $server = "messenger.hotmail.com";<br>
private $port = 1863;<br>
private $nexus = "https://nexus.passport.com/rdr/pprdr.asp";<br>
private $sshLogin = "login.live.com/login2.srf"; //loginnet.passport.com/login2.srf<br>
private $getCode = null;<br>
private $_ip = null;<br>
private $_port = null;<br>
private $connect = null;<br>
private $trID = 1;<br>
private $maxMessage = 4096;<br>
private $userName = null;<br>
private $passWord = null;<br>
private $debug = true;<br>
function myMSN($userName="", $passWord="") {<br>
if (!empty($userName) && !empty($passWord)) {<br>
$this->userName = $userName;<br>
//$this->passWord = urlencode($passWord);<br>
$this->passWord = $passWord;<br>
$this->startTalk();<br>
}<br>
}<br>
function put($data) {<br>
if ($this->isConnect()) {<br>
fputs($this->connect, $data);<br>
$this->trID ;<br>
if ($this->debug)<br>
print("<div style="color:green;font-size:13px;">>>>{$data}</div>");<br>
}<br>
}<br>
function get() {<br>
if ($data = @fgets($this->connect, $this->maxMessage)) {<br>
if ($this->debug)<br>
print("<div style="color:red;font-size:13px;">");<br>
return $data;<br>
} else {<br>
return false;<br>
}<br>
}<br>
function isConnect() {<br>
if (!is_null($this->connect))<br>
return true;<br>
else<br>
return false;<br>
}<br>
function close() {<br>
@fclose($this->connect);<br>
}<br>
function startTalk() {<br>
if ($this->connect = fsockopen($this->server, $this->port, $errno, $errstr, 2))<br>
$this->verTalk();<br>
}<br>
function verTalk() // MSN 协议协商 {<br>
$this->put("VER {$this->trID} MSNP9 CVR0 rn");<br>
$data = $this->get();<br>
//echo $data;<br>
if (false !== strripos($data, "VER"))<br>
$this->envTalk();<br>
}<br>
function envTalk() // 环境协商 {<br>
$this->put("CVR {$this->trID} 0x0409 winnt 5.0 i386 MSNMSGR 7.0.0816 MSMSGS {$this->userName} rn");<br>
$data = $this->get();<br>
//echo $data;<br>
if (false !== strripos($data, "CVR"))<br>
$this->reqTalk();<br>
}<br>
function reqTalk() // 请求确认 {<br>
$this->put("USR {$this->trID} TWN I {$this->userName} rn");<br>
$data = $this->get(); // XFR 3 NS 207.46.107.41:1863 0 65.54.239.210:1863 XFR 3 NS 207.46.107.25:1863 U D<br>
//echo $data;<br>
if (false !== strripos($data, "XFR")) {<br>
list(, , , $serv) = explode(" ", $data); // 分析服务器<br>
list($ip, $port) = explode(":", $serv); // 分析IP和端口<br>
$this->_ip = $ip;<br>
$this->_port = $port;<br>
$this->reLink($ip, $port);<br>
} else {<br>
//echo $data; // USR 3 TWN S ct=1205292058,rver=5.0.3270.0,wp=FS_40SEC_0_COMPACT,lc=1033,id=507,ru=http://messenger.msn.com,tw=0,kpp=1,kv=4,ver=2.1.6000.1,rn=1lgjBfIL,tpf=b0735e3a873dfb5e75054465196398e0<br>
list(, , , , $this->getCode) = explode(" ", trim($data));<br>
//echo $data;<br>
if (empty($this->sshLogin))<br>
$this->reLoginTalk(); // 重新获取登陆服务器地址<br>
else<br>
$this->getLoginCode($this->sshLogin);<br>
}<br>
}<br>
function reLink($server, $port) // 重置连接 {<br>
$this->connect = null;<br>
$this->server = $server;<br>
$this->port = $port;<br>
$this->trID = 1;<br>
$this->startTalk();<br>
}<br>
function reLoginTalk() // 重新获取服务器地址 {<br>
$ch = curl_init($this->nexus);<br>
curl_setopt($ch, CURLOPT_HEADER, 1);<br>
curl_setopt($ch, CURLOPT_NOBODY, 1);<br>
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);<br>
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);<br>
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);<br>
$header = curl_exec($ch);<br>
//print_r($header);<br>
curl_close($ch);<br>
preg_match (/DALogin=(.*?),/, $header, $out); // 捕捉服务器登陆匹配<br>
//print_r($out);<br>
if (isset($out[1])) {<br>
$this->getLoginCode($out[1]);<br>
}<br>
else {<br>
//return false;<br>
exit("无法捕捉到登陆服务器的URL");<br>
}<br>
}<br>
function getLoginCode($slogin) // 获取登陆代码 {<br>
//echo($this->getCode);<br>
if (!is_null($this->getCode)) {<br>
$ch = curl_init("https://" . $slogin);<br>
$loginInfo = array(<br>
"Authorization: Passport1.4 rgVerb=GET,OrgURL=http://messenger.msn.com,sign-in=" . $this->userName . ",pwd=" . $this->passWord . "," . $this->getCode,<br>
"Host: login.passport.com"<br>
);<br>
curl_setopt($ch, CURLOPT_HTTPHEADER, $loginInfo);<br>
//print_r($loginInfo);<br>
//$this->getCode = null;<br>
curl_setopt($ch, CURLOPT_HEADER, 1);<br>
curl_setopt($ch, CURLOPT_NOBODY, 1);<br>
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);<br>
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);<br>
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
</div></font>

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu
