sharepoint form认证下跨域访问其他基本认证的系统(客户端用js的xmlhttprequest)的方法...

只想到客户端的,而且不是很安全,因为直接用js传了用户名密码。希望高手能指点一二。而且如果能从服务器端解决问题就更好了!

 

 

ExpandedBlockStart.gif 代码
// 获取数据


var  Request  =   new  Object();

Request.send 
=   function (url, method, callback, data, urlencoded,uid,pwd) {

    
var  req;
    
if  (window.XMLHttpRequest) { // 非IE内核浏览器
        req  =   new  XMLHttpRequest();
    }
    
else   if  (window.ActiveXObject) { // IE内核浏览器
         try  { // IE6.0
            req  =   new  ActiveXObject( " Microsoft.XMLHTTP " );
        }
        
catch  (e1) {
            
try  {
                req 
=   new  ActiveXObject( " MSXML2.XMLHTTP " );
            }
            
catch  (e2) {
                
try  {
                    req 
=   new  ActiveXObject( " MSXML3.XMLHTTP " );
                }
                
catch  (e3) {
                    alert(
" 创建Ajax失败: "   +  e3)
                }
            }
        }
    }
    
else  { // 未知浏览器
        alert( " 未能识别的浏览器 " );
    }


    req.onreadystatechange 
=   function () {
        
if  (req.readyState  ==   4 ) { //  only if req shows "loaded"
             if  (req.status  <   400 ) { //  only if "OK"
                (method  ==   " POST " ?  callback(req) : callback(req, data);
            } 
else  {
                
// alert("There was a problem loading data :\n" + req.status+ "/" + req.statusText + "\n" + url);
            }
        }
    }
//     debugger;
     if  (method  ==   " POST " ) {
        req.open(
" POST " , url,  true ,uid,pwd);
        
if  (urlencoded) req.setRequestHeader( ' Content-Type ' ' application/x-www-form-urlencoded ' );
        req.send(data);
    } 
else  {
        req.open(
" GET " , url,  true ,uid,pwd);
        req.send(
null );
    }

    
return  req;
}

Request.sendRawPOST 
=   function (url, data, callback) {
    Request.send(url, 
" POST " , callback, data,  false );
}
Request.sendPOST 
=   function (url, data, callback,uid,pwd) {
    Request.send(url, 
" POST " , callback, data,  true ,uid,pwd);
}
Request.sendGET 
=   function (url, callback, args) {
    
return  Request.send(url,  " GET " , callback, args);
}



// 直接跳转到页
function  GetRC(url, username, password) {

    
var  req_oa;

    
if  (window.XMLHttpRequest) { // 非IE内核浏览器
        req_oa  =   new  XMLHttpRequest();
    }
    
else   if  (window.ActiveXObject) { // IE内核浏览器
         try  { // IE6.0
            req_oa  =   new  ActiveXObject( " Microsoft.XMLHTTP " );
        }
        
catch  (e1) {
            
try  {
                req_oa 
=   new  ActiveXObject( " MSXML2.XMLHTTP " );
            }
            
catch  (e2) {
                
try  {
                    req_oa 
=   new  ActiveXObject( " MSXML3.XMLHTTP " );
                }
                
catch  (e3) {
                    alert(
" 创建Ajax失败: "   +  e3)
                }
            }
        }
    }
    
else  { // 未知浏览器
        alert( " 未能识别的浏览器 " );
    }

    req_oa.open(
" POST " , url,  true , username, password);

    req_oa.onreadystatechange 
=   function  Result() {


        
if  (req_oa.readyState  ==   4 ) { //  only if req shows "loaded"
             if  (req_oa.status  <   400 ) { //  only if "OK"
                self.location  =  url;
            }
            
else  {
                
// alert("There was a problem loading data :\n" + req.status+ "/" + req.statusText + "\n" + url);
            }
        }
    }
    req_oa.send(
null );
}

 

 

转载于:https://www.cnblogs.com/liukai/archive/2009/12/25/1632286.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值