首先要說的是,閣下的問題看起頗費神,中文英文符號混雜,大小寫混雜,讓閱讀者看起相當吃力。
我們提供的服務有:做網(wǎng)站、網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、尖草坪ssl等。為1000+企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的尖草坪網(wǎng)站制作公司
其次,你跨域,JS不能使用POST和GET請求的,這是瀏覽器安全規(guī)則,不過可以使用其它辦法來獲得類似結(jié)果。
JS跨域,POST可以通過提交隱藏表單至隱藏框架頁來得到請求結(jié)果。而GET請求則可以在目標地址后面加上要請求的GET參數(shù)然后抓取目標頁的所有網(wǎng)頁內(nèi)容,再通過正則處理獲得結(jié)果;也可以使用JSON來獲取(詳情請自行學習JSON,很簡單的)。
閣下的問題,只是獲取COOKIE時間,那么可以直接通過JS抓取目標頁或JSON獲得。而B域名的cookies.php,完全不需要訪問index.php來獲得上一個COOKIE的時間,因為它們是同一個站,index.php能訪問到的COOKIE,cookies.php也能訪問到。
B域名的cookies.php參考如下(僅供參考,具體請根據(jù)自己情況另行寫代碼):
if(isset($_COOKIE["user"]))//
$time?=?$_COOKIE["user"];//
else
$time?=?0;//
$_COOKIE["user"]?=?time();
echo?$time;
//或輸出JSON,請自行學習
終上,僅是提供一個思路,更多的還是要靠閣下自行摸索學習。
另外,這種跨域請求,建議使用JSON,因為它簡單方便。當你學會了,就表示你會寫接口和使用接口了(雖然這個只是最簡單的接口)。當然除了JSON還可以使用XML,只是性能稍差一些,也不錯
php中的文件讀寫函數(shù)基本上都可直接支持url,也就是說你可以像操作本地文件一樣直接操作其他網(wǎng)站的文件(當然只是讀取,寫入是不可能的),而且沒有任何跨域限制,比如下面一行代碼就可直接讀取百度首頁的html代碼:
$bd=file_get_contents("");
如果想獲取json數(shù)據(jù),只需把網(wǎng)址換一下即可。當然,還需要做一下格式轉(zhuǎn)換,php本身就有專門的json轉(zhuǎn)換函數(shù):
$json=json_decode(file_get_contents("網(wǎng)址"),true);
這樣一看,是不是比前端的ajax還要簡單百倍?!
php不存在跨域問題,只有前段語言才會有.
php里面 curl 就是跨域請求數(shù)據(jù)的內(nèi)置函數(shù),它可以post,get,file都能實現(xiàn)。請求地址的時候注意加上http/https
因工作需要,客戶端軟件的一些界面用HTML+CSS+Javascript實現(xiàn),這些文件放在客戶端本地,以本地文件形式加載,但是有些情況下,需要連接服務器取得一些信息,如果不做任何處理,則請求失敗,返回的信息如下:
No
'Access-Control-Allow-Origin'
header
is
present
on
the
requested
resource.
Origin
'null'
is
therefore
not
allowed
access.
這是因為瀏覽器跨域策略起作用,阻止了跨域的請求。看看HTTP請求過程就知道。第一次請求后端時候,瀏覽器意識到是訪問一個跨與資源,沒有直接發(fā)送GET請求獲取數(shù)據(jù),而是發(fā)送了一個OPTIONS請求詢問是否可以訪問該資源。我們稱之為Preflight請求,默認因為同源策略的存在,該請求返回的Header中沒有'Access-Control-Allow-Origin'屬性,所以訪問失敗。
如果要實現(xiàn)跨域,關鍵在于服務器,客戶端的代碼按照正常的方式編寫即可。對于服務器,只需要在收到OPTIONS請求的地方,返回的頭信息中增加該屬性即可,代碼如下:
header("Access-Control-Allow-Origin:
*");
注意,一定要在所有信息輸出到客戶端之前設置。
以上所述是小編給大家介紹的PHP如何實現(xiàn)跨域的相關內(nèi)容,希望對大家有所幫助!