Frage

Ich versuche, einen OAuth-Anbieter mit PHP zu erstellen und es ist offiziell oauth Klasse.

Ich versuche nur, die Anfrage des Provider Griff zu machen, aber es gibt mir zwei segfault tatsächlich.

Hier ist mein Provider

<?php

    class Provider{

        private $oauth;

        public function __construct(){

            try {

            /* create our instance */
            $this->oauth = new OAuthProvider();

            /* setup check functions */
            $this->oauth->consumerHandler(array($this,'checkConsumer'));
            $this->oauth->timestampNonceHandler(array($this,'checkNonce'));
            $this->oauth->tokenHandler(array($this,'checkToken'));

            /* If we are issuing a request token we need to disable checkToken */
            if(strstr($_SERVER['REQUEST_URI'],"oauth/request_token")){
                $this->oauth->isRequestTokenEndpoint(true); 
            }

            /* now that everything is setup we run the checks */
                $this->oauth->checkOAuthRequest(null,OAUTH_HTTP_METHOD_GET);
            } catch(OAuthException $E){
                echo OAuthProvider::reportProblem($E);
                $this->oauth_error = true;
            }


        }

        public function checkConsumer($provider){
            $provider->consumer_secret = "secret";
            return OAUTH_OK;
        }

        public function checkToken($provider){
            return OAUTH_OK;
        }

        public function checkNonce($provider){
            return OAUTH_OK;
        }

    }
?>

Und hier ist mein Kunde, dass ich zum Testen verwenden.

<?php
    $oauth_client = new Oauth("key","secret");
    try {
        $oauth_client->getRequestToken("http://localhost/OAuthProviderExample/oauth/request_token");
    } catch(OAuthException $E){
        echo $E;
    }
?>

Der Client Ausgang dieses

exception 'OAuthException' with message 'making the request failed (dunno why)' in /var/www/OAuthProviderExample/client/index.php:4 Stack trace: #0 /var/www/OAuthProviderExample/client/index.php(4): OAuth->getRequestToken('http://localhos...') #1 {main}

Und das Fehlerprotokoll zeigt diese

[Fri Jan 07 09:33:45 2011] [notice] child pid 3662 exit signal Segmentation fault (11)
[Fri Jan 07 09:33:45 2011] [notice] child pid 3663 exit signal Segmentation fault (11)

Ich habe keine Ahnung, was jetzt zu tun!

War es hilfreich?

Lösung

Anscheinend gibt es einen Fehler in der Version 1.0.0 in PECL.

Kompilieren von Stamm regelte es für mich

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top