0

php 5.4をサポートするWebホスティングで、facebook php api 4.0に基づいて、facebookログイン用のスクリプトをアップロードしましたが、取得しています

警告: is_readable(): open_basedir 制限が有効です。ファイル (/dev/urandom) が許可されたパス内にありません: (/home/myuserid:/usr/lib/php:/tmp) の /home/myuserid/public_html/Facebook/FacebookRedirectLoginHelper.php 行 244

ファイルの 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 Facebook\FacebookSession;
use Facebook\FacebookRedirectLoginHelper;
use Facebook\FacebookRequest;
use Facebook\FacebookResponse;
use Facebook\FacebookSDKException;
use Facebook\FacebookRequestException;
use Facebook\FacebookAuthorizationException;
use Facebook\GraphObject;

// 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 を使用すると、スクリプトは完全に機能します

4

2 に答える 2

1

ほとんどの共有ホスティング プロバイダーは、ユーザーを積極的に制限して、他のユーザーのコンテンツやシステム リソースにアクセスできないようにしています。

この場合、彼らopen_basedirは php.ini のオプションを使用しました。このオプションは、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 以降で使用できます。

于 2014-07-27T18:12:46.700 に答える
0

この警告メッセージは、バージョン で修正された SDK のバグが原因で発生しました4.0.10。@Pierto が提案したようにサーバー環境を変更できない場合は、最新の安定バージョンの4.0 SDKをダウンロードできます。

于 2014-09-02T13:25:25.423 に答える