通过Azure移动服务和cordova应用程序使用自定义身份验证器进

时间:2014-10-13 17:56:20

标签: authentication azure-mobile-services

我正在使用Cordova / Phonegap和Azure移动服务后端构建手机应用程序。我需要使用自定义验证器,因为它与当前的软件产品集成。

我使用http://azure.microsoft.com/en-us/documentation/articles/mobile-services-dotnet-backend-get-started-custom-authentication/

中的信息构建了服务器端

我在config.SetIsHosted(true);

中设置WebApiConfig

从客户端,我似乎正在验证罚款并获得有效的令牌,但我不知道如何处理它。我已经尝试设置client.currentUser,但我的api电话会以未经授权的方式返回。

这里有一些代码:

client = new WindowsAzure.MobileServiceClient("http://`localhost`:50523");      
login = function () {
    client.invokeApi("CustomLogin", {
    method: "post",
    body: { "username": "user1", "password": "pass1" }
    })
    .done(function (result) {
        var login = JSON.parse(result.response);
        client.currentUser = login.user;
        client.currentUser.mobileServiceAuthenticationToken = login.authenticationToken;

        //lets try now that i'm valid
        getMembers();

        app.navigate("views/home.html");
    }, function(error) {
        alert(error);
        });

};

    getMembers = function () {
        client.invokeApi("Member", {
            method: "get",
            body: {}
            })
        .done(
        function(result) {
            alert(result.result[0].lName);
            },
        function(error) {
            alert(error);
            });

    };

我是否需要使用身份验证令牌才能使其正常工作? 谢谢!

编辑:更多信息 -

使用Fiddler监控流量,我看到对/api/member的调用设置了几个标头:

X-ZUMO-AUTH: set to the token I got back earlier
X-ZUMO-FEATURES: AJ
X-ZUMO-INSTALLATION-ID: a guid
X-ZUMO-VERSION: ZUMO/1.2(...)

1 个答案:

答案 0 :(得分:0)

行。仔细看了这个。首先,该示例仅在本地Azure移动服务数据库中创建用户。我假设您正在Azure中的实际移动服务上创建用户。您可以看到我在下面注释的代码行,如果您想测试,可以添加它。但这里的代码应该做你想要的。对不起,它是C#,但应该很容易翻译。注意" UserToDo"是我的CustomLoginProvider.ProviderName返回的字符串。

protected override async void OnNavigatedTo(NavigationEventArgs e)
{
    LoginInfo dude = new LoginInfo() { username = "user", password = "P-Dub" };

    //  await App.MobileService.InvokeApiAsync<LoginInfo, LoginResult>("CustomRegistration", dude);

    //  Call Custom API To Log iN
    var result = await App.MobileService.InvokeApiAsync<LoginInfo,LoginResult>("CustomLogin", dude);

    // Create the user credentials.
    PasswordCredential credential = new PasswordCredential("UserToDo",
        result.user.userId, result.authenticationToken);

    MobileServiceUser user = new MobileServiceUser(credential.UserName);
    credential.RetrievePassword();
    user.MobileServiceAuthenticationToken = credential.Password;

    // Set the user from the stored credentials.
    App.MobileService.CurrentUser = user;


    await RefreshTodoItems();  // This accesses the mobile service.
}


public class LoginInfo
{
    public String username { get; set; }
    public String password { get; set; }
}


public class LoginResult
{
    public User user { get; set; }
    public string authenticationToken { get; set; }
}

public class User
{
    public string userId { get; set; }
}