basedir限制有效“

我已经上传了我的facebook登录脚本,基于facebook php api 4.0,在一个支持php 5.4的网络托管上,但是我得到了

警告:is_readable():有效的open_basedir限制。 文件(/ dev / urandom)不在/ 244行的/home/myuserid/public_html/Facebook/FacebookRedirectLoginHelper.php中的允许路径:(/ home / myuserid:/ usr / lib / php:/ tmp)

这里是文件的第244行和下面的一些内容

if (is_readable('/dev/urandom')) {
  $fp = fopen('/dev/urandom', 'rb');
  if ($fp !== FALSE) {
    $buf = fread($fp, $bytes);
    fclose($fp);
    if($buf !== FALSE) {
      return bin2hex($buf);
    }
  }
}

如果它可能有帮助,这里是基本的登录脚本:

<?php
session_start();
require_once('Facebook/Entities/AccessToken.php');
require_once( 'Facebook/FacebookSession.php' );
require_once( 'Facebook/FacebookRedirectLoginHelper.php' );
require_once('Facebook/HttpClients/FacebookHttpable.php');
require_once('Facebook/HttpClients/FacebookCurl.php');
require_once('Facebook/HttpClients/FacebookCurlHttpClient.php');
require_once( 'Facebook/FacebookRequest.php' );
require_once( 'Facebook/FacebookResponse.php' );
require_once( 'Facebook/FacebookSDKException.php' );
require_once( 'Facebook/FacebookRequestException.php' );
require_once( 'Facebook/FacebookAuthorizationException.php' );
require_once( 'Facebook/GraphObject.php' );

use FacebookFacebookSession;
use FacebookFacebookRedirectLoginHelper;
use FacebookFacebookRequest;
use FacebookFacebookResponse;
use FacebookFacebookSDKException;
use FacebookFacebookRequestException;
use FacebookFacebookAuthorizationException;
use FacebookGraphObject;

// init app with app id (APPID) and secret (SECRET)
FacebookSession::setDefaultApplication('','');

// login helper with redirect_uri
$helper = new FacebookRedirectLoginHelper( 'http://mysite/fb.php' );

try {
  $session = $helper->getSessionFromRedirect();
} catch( FacebookRequestException $ex ) {
  // When Facebook returns an error
} catch( Exception $ex ) {
  // When validation fails or other local issues
}

// see if we have a session
if ( isset( $session ) ) {
  // graph api request for user data
  $request = new FacebookRequest( $session, 'GET', '/me' );
  $response = $request->execute();
  // get response
  $graphObject = $response->getGraphObject();

//[...] uses data to login
} else {
  // show login url
  echo '<a href="' . $helper->getLoginUrl() . '">Login</a>';
}
?>

注意:本地使用easyPHP,脚本完美地工作


大多数共享主机提供商主动限制用户阻止他们访问其他用户的内容和系统资源。

在这种情况下,他们使用php.ini中的open_basedir选项,该选项只允许PHP在指定路径中打开文件,并拒绝其他所有访问。

要解决这个问题,你可以要求他们授予你对/dev/urandom访问权限,他们可能不会这样做,或者用下面的代码替换你的代码:

if (function_exists('openssl_random_pseudo_bytes')) {
    return bin2hex(openssl_random_pseudo_bytes($bytes));
}

openssl_random_pseudo_bytes函数几乎完全一样,可在PHP 5.3.0或更高版本上使用。


此警告消息是由版本4.0.10中修复的SDK中的错误引起的。 如果您无法像@Pierto建议的那样更改服务器环境,则可以下载4.0 SDK的最新稳定版本。

链接地址: http://www.djcxy.com/p/69263.html

上一篇: basedir restriction in effect"

下一篇: dir() [function.is