`

Ionic2 Rest 认证

 
阅读更多

今天,我们使用REST API实现用户名密码认证,服务端端点如下:

Endpoint 请求 响应
/login { username: '',password: '' } auth_token
/logout add a token to headers  
/register { username: '', password: '' }

1、创建Ionic 2 APP

反复练习,应该是很熟悉了:

ionic start Ionic2RestAuth --v2

我习惯上会先启动看看,确保项目创建成功:

cd Ionic2RestAuth
ionic serve --lab

看到如下界面应该就可以放心了:


Ionic应用界面

2、创建服务

我们需要创建一个服务来访问REST Api,命令如下:

ionic g provider AuthService

我们创建对应的方法来访问注册、登陆、登出REST。

修改 src/providers/auth-service.ts如下:

import { Injectable } from '@angular/core';
import { Http, Headers } from '@angular/http';
import 'rxjs/add/operator/map';

let apiUrl = 'http://localhost:8080/api/';

@Injectable()
export class AuthService {

  constructor(public http: Http) {}

  login(credentials) {
    return new Promise((resolve, reject) => {
        let headers = new Headers();
        headers.append('Content-Type', 'application/json');

        this.http.post(apiUrl+'login', JSON.stringify(credentials), {headers: headers})
          .subscribe(res => {
            resolve(res.json());
          }, (err) => {
            reject(err);
          });
    });
  }

  register(data) {
    return new Promise((resolve, reject) => {
        let headers = new Headers();
        headers.append('Content-Type', 'application/json');

        this.http.post(apiUrl+'guest/signup', JSON.stringify(data), {headers: headers})
          .subscribe(res => {
            resolve(res.json());
          }, (err) => {
            reject(err);
          });
    });
  }

  logout(){
    return new Promise((resolve, reject) => {
        let headers = new Headers();
        headers.append('X-Auth-Token', localStorage.getItem('token'));

        this.http.post(apiUrl+'logout', {}, {headers: headers})
          .subscribe(res => {
            localStorage.clear();
          }, (err) => {
            reject(err);
          });
    });
  }

}

接下来修改 src/app/app.module.ts 中的 import 和 @NgModule providers:

...
import { AuthService } from '../providers/auth-service';
...
providers: [{provide: ErrorHandler, useClass: IonicErrorHandler}, AuthService]
...

3、创建登陆和注册页面

我们需要创建相应的页面实现登陆和注册,如下命令将自动生成视图、控制器和样式文件:

ionic g page Login
ionic g page Register

修改' src/app/app.module.ts' wen文件如下:

import { LoginPage } from '../pages/login/login';
import { RegisterPage } from '../pages/register/register';

@NgModule({
  declarations: [
    MyApp,
    AboutPage,
    ContactPage,
    HomePage,
    TabsPage,
    LoginPage,
    RegisterPage
  ],
  imports: [
    IonicModule.forRoot(MyApp)
  ],
  bootstrap: [IonicApp],
  entryComponents: [
    MyApp,
    AboutPage,
    ContactPage,
    HomePage,
    TabsPage,
    LoginPage,
    RegisterPage
  ],
  providers: [{provide: ErrorHandler, useClass: IonicErrorHandler}, AuthService]
})

修改 src/pages/login/login.ts 文件如下:

import { Component } from '@angular/core';
import { NavController, LoadingController, ToastController } from 'ionic-angular';
import { AuthService } from '../../providers/auth-service';
import { TabsPage } from '../tabs/tabs';
import { RegisterPage } from '../register/register';

@Component({
  selector: 'page-login',
  templateUrl: 'login.html'
})
export class LoginPage {

  loading: any;
  loginData = { username:'', password:'' };
  data: any;

  constructor(public navCtrl: NavController, public authService: AuthService, public loadingCtrl: LoadingController, private toastCtrl: ToastController) {}

  doLogin() {
    this.showLoader();
    this.authService.login(this.loginData).then((result) => {
      this.loading.dismiss();
      this.data = result;
      localStorage.setItem('token', this.data.access_token);
      this.navCtrl.setRoot(TabsPage);
    }, (err) => {
      this.loading.dismiss();
      this.presentToast(err);
    });
  }

  register() {
    this.navCtrl.push(RegisterPage);
  }

  showLoader(){
    this.loading = this.loadingCtrl.create({
        content: 'Authenticating...'
    });

    this.loading.present();
  }

  presentToast(msg) {
    let toast = this.toastCtrl.create({
      message: msg,
      duration: 3000,
      position: 'bottom',
      dismissOnPageChange: true
    });

    toast.onDidDismiss(() => {
      console.log('Dismissed toast');
    });

    toast.present();
  }

}

修改 pages/login/login.html 文件如下:

<ion-content padding>
  <h2>Please, Login</h2>
  <form (submit)="doLogin()">
    <ion-item>
      <ion-label stacked>Username</ion-label>
      <ion-input [(ngModel)]="loginData.username" name="username" type="text" placeholder="Username" ></ion-input>
    </ion-item>
    <ion-item>
      <ion-label stacked>Password</ion-label>
      <ion-input [(ngModel)]="loginData.password" name="password" type="password" placeholder="Password"></ion-input>
    </ion-item>
    <button ion-button block type="submit">
      Login
    </button>
  </form>

  <button ion-button block clear (click)="register()">
    No have an account? Register Now
  </button>
</ion-content>

修改 edit pages/register/register.ts 如下:

import { Component } from '@angular/core';
import { NavController, NavParams, LoadingController, ToastController } from 'ionic-angular';
import { AuthService } from '../../providers/auth-service';

@Component({
  selector: 'page-register',
  templateUrl: 'register.html'
})
export class RegisterPage {

  loading: any;
  regData = { username:'', password:'' };

  constructor(public navCtrl: NavController, public navParams: NavParams, public authService: AuthService, public loadingCtrl: LoadingController, private toastCtrl: ToastController) {}

  doSignup() {
    this.showLoader();
    this.authService.register(this.regData).then((result) => {
      this.loading.dismiss();
      this.navCtrl.pop();
    }, (err) => {
      this.loading.dismiss();
      this.presentToast(err);
    });
  }

  showLoader(){
    this.loading = this.loadingCtrl.create({
        content: 'Authenticating...'
    });

    this.loading.present();
  }

  presentToast(msg) {
    let toast = this.toastCtrl.create({
      message: msg,
      duration: 3000,
      position: 'bottom',
      dismissOnPageChange: true
    });

    toast.onDidDismiss(() => {
      console.log('Dismissed toast');
    });

    toast.present();
  }

}

修改 pages/register/register.html 如下:

<ion-content padding>
  <h2>Register Here</h2>
  <form (submit)="doSignup()">
    <ion-item>
      <ion-label stacked>Username</ion-label>
      <ion-input [(ngModel)]="regData.username" name="username" type="text" placeholder="Your username" ></ion-input>
    </ion-item>
    <ion-item>
      <ion-label stacked>Password</ion-label>
      <ion-input [(ngModel)]="regData.password" name="password" type="password" placeholder="Your password"></ion-input>
    </ion-item>
    <button ion-button block type="submit">
      SignUp
    </button>
  </form>
</ion-content>

4、登出和token检查

最后,在主页中添加一个退出登陆的功能,同时检查token,如果没有token跳转到登陆页面。

编辑 pages/tabs/tabs.ts 文件如下:

import { Component } from '@angular/core';
import { NavController } from 'ionic-angular';
import { HomePage } from '../home/home';
import { AboutPage } from '../about/about';
import { ContactPage } from '../contact/contact';
import { LoginPage } from '../login/login';

@Component({
  templateUrl: 'tabs.html'
})
export class TabsPage {
  // this tells the tabs component which Pages
  // should be each tab's root Page
  tab1Root: any = HomePage;
  tab2Root: any = AboutPage;
  tab3Root: any = ContactPage;

  constructor(public navCtrl: NavController) {
    if(!localStorage.getItem("token")) {
      navCtrl.setRoot(LoginPage);
    }
  }
}

编辑 pages/home/home.ts 文件如下:

import { Component } from '@angular/core';
import { AuthService } from '../../providers/auth-service';
import { NavController, App, LoadingController, ToastController } from 'ionic-angular';
import { LoginPage } from '../login/login';

@Component({
  selector: 'page-home',
  templateUrl: 'home.html'
})
export class HomePage {

  loading: any;
  isLoggedIn: boolean = false;

  constructor(public app: App, public navCtrl: NavController, public authService: AuthService, public loadingCtrl: LoadingController, private toastCtrl: ToastController) {
    if(localStorage.getItem("token")) {
      this.isLoggedIn = true;
    }
  }

  logout() {
    this.authService.logout().then((result) => {
      this.loading.dismiss();
      let nav = this.app.getRootNav();
      nav.setRoot(LoginPage);
    }, (err) => {
      this.loading.dismiss();
      this.presentToast(err);
    });
  }

  showLoader(){
    this.loading = this.loadingCtrl.create({
        content: 'Authenticating...'
    });

    this.loading.present();
  }

  presentToast(msg) {
    let toast = this.toastCtrl.create({
      message: msg,
      duration: 3000,
      position: 'bottom',
      dismissOnPageChange: true
    });

    toast.onDidDismiss(() => {
      console.log('Dismissed toast');
    });

    toast.present();
  }

}

Home页面的登出按钮:

<ion-header>
  <ion-navbar>
    <button ion-button clear (click)="logout()">
      <ion-icon name="log-out"></ion-icon>
    </button>
    <ion-title>Home</ion-title>
  </ion-navbar>
</ion-header>

好了,测试一下:

ionic serve --lab

整个功能界面应该是这个样子的:


Rest API 功能界面

五一更一发,更多内容请查看百度阅读:

Ionic 2 实例开发


Ionic 2 安装
环境安装
创建Ionic项目
测试运行项目
Ionic 2 项目结构
./src/index.html
./src/
./src/app/app.html
Ionic 2 应用剖析
0 开始之前
1 创建一个新的Ionic 2 应用
2 目录结构
Root Components 模版
App Module
总结
Ionic 2 添加页面
创建页面
创建附加页面
使用 Ionic 2 开发Todo应用
0 开始之前
1 创建新的Ionic 2工程
2. 设置主页(Home page)
3 持久化数据保存
4 总结
Ionic 2 实现列表滑动删除按钮
1.创建Ionic2应用
2.准备列表数据
3.修改主页(HOME)的模版
4.创建方法删除数据
5.添加一个编辑按钮
总结
Angular 2 新概念和语法
Angular 2 & Ionic 2 概念
Angular 2 语法
Ionic 2 导航简明指南
入栈出栈(Pushing and Popping)
什么时候使用导航栈?什么时候使用rootPage?
Ionic 2 基本导航功能
总结
Ionic 2 中使用管道处理数据
1.生成一个新应用
2.创建一个管道
3.使用管道
总结
Ionic 2 中使用HTTP与远程服务器交互数据
开始之前
我们需要一个列表
3.获取远程数据
4.推送数据到服务器
总结
Ionic 2 中的样式与主题
Ionic 2主题简介
创建Ionic 2应用主题的方式
没有苹果电脑打包iOS平台的 Ionic 2程序
开始之前
1 创建一个Ionic 2的应用
2 建立Ionic Cloud
3 生成证书和创建一个安全概要
4 使用Ionic Package 命令
总结
Ionic 2中使用百度地图和Geolocation
新建项目
加入百度地图SDK库
加载地图
获取定位
坐标转换
地图定位
激活百度地图导航
总结
在Ionic 2 Native中使用Cordova插件
Ionic 和 Cordova 的误解
使用Ionic Native
使用没有包含在Ionic Native中的插件
Ionic 2 中添加图表
1. 照例新建一个项目
2. 安装Chart.js
3. 在模版中使用
总结
Ionic 2 中的创建一个闪视卡片组件
1. 创建一个新的应用作为例子
2. 什么是组件?
3. 创建组件模版
4. 创建组件类
5. 创建 CSS 动画
6. 添加组件到模版
总结
Ionic 2 中创建一个照片倾斜浏览组件
1. 创建一个新的应用
2. 实现照片倾斜浏览组件
3. 使用照片倾斜浏览组件
总结
Ionic 2 中实现一个简单的进度条
理解 自定义组件中的 Input 和 output
1.创建一个新的应用
2.创建组件
修改src/components/progress-bar/progress-bar.ts如下:
3.使用这个组件
总结
使用VS Code在Chrome中调试Ionic 2
优化你的Ionic2应用
打开Angular产品模式
修改(click) 为 (tap)
使用 --prod 参数编译
总结
Ionic 2 开发遇到的问题及处理集
Console.log 不输出
编译Android报错:compileArmv7DebugJavaWithJavac
一些更新命令
错误:Error: listen EADDRINUSE 0.0.0.0:53703

转载请注明:
http://www.techcave.cn
http://tedum.iteye.com

 

0
0
分享到:
评论

相关推荐

    ionic-todo-node

    2. **AngularJS**:AngularJS 是一个用于构建客户端 Web 应用的 JavaScript 框架,由 Google 维护。它使用 MVC(模型-视图-控制器)架构模式,提供了数据绑定、依赖注入、指令等特性,简化了前端开发流程。 3. **...

    ionic2-salesforce-sample:样品申请

    - **实现 OAuth 认证**:Ionic 应用通过 Cordova 插件与 Salesforce OAuth 集成,确保用户身份验证的安全。开发者需要理解如何处理 token 的刷新和过期,以及如何在不同平台(iOS、Android)上处理登录逻辑。 - **...

    ionic-Bloging-app

    开发者可以通过阅读源代码,学习如何配置Ionic项目、设置路由、处理API请求、集成Drupal的REST接口、实现用户认证逻辑等。 在**ionic-Bloging-app-master**这个压缩包中,包含了整个项目的源代码结构,如HTML模板...

    springboot-ionic-backend

    标题 "springboot-ionic-backend" 暗示我们讨论的是一个使用Spring Boot后端技术和Ionic前端框架构建的应用项目。Spring Boot是Java生态系统中的一个流行框架,用于简化Spring应用程序的初始设置和配置,而Ionic则是...

    course-ionic:Projeto Udemy,Spring boot,Hibernate,REST,ionic,JWT,S3,Mysql

    2. **Hibernate**:这是一款Java领域的关系型数据持久化框架,简化了数据库操作。它允许开发者用面向对象的方式来处理数据库,使得数据库访问更加直观和高效。 3. **REST**:Representational State Transfer(表述...

    SpringBoot_REST_Ionic:使用Java comSpring启动来构建复杂的后端组合。 批准了一个公开的um MVP de baixo custo usando Ionic的评论员

    标题中的“SpringBoot_REST_Ionic”表明我们正在讨论一个项目,该项目使用了Spring Boot作为后端框架,并且通过RESTful API与Ionic前端进行交互。这是一个常见的现代Web开发架构,其中Spring Boot提供服务,而Ionic...

    Curso-Spring-Boot:Curso de Spring Boot,Hibernate,REST,Ionic,JWT,S3和MySQL做教授Nelio Alves

    《Spring Boot深度解析:结合Hibernate、REST、Ionic、JWT、S3与MySQL的实战课程》 本课程由知名讲师Nelio Alves主讲,旨在深入讲解Spring Boot框架的使用,以及如何与其他技术如Hibernate、RESTful API、Ionic前端...

    curso-spring-ionic-frontend

    2. JWT身份验证:使用Spring Security实现JSON Web Tokens(JWT)进行用户认证和授权。 3. RESTful API设计:理解REST原则并创建符合标准的API接口。 4. Ionic组件和指令:学习如何使用Ionic的预定义组件(如页签、...

    Ionic-Framework-Learning:大量的博客文章,文章,视频等链接,用于学习Ionic Framework

    指令认证类别代码组织测试REST风格的东西本地化UI的东西集成其他语言/框架移动流行的第三方模块开发工具[社区](#community论坛) ##一般的 官方网站 文件资料 Github资料库 展示柜 学习离子 ##图书 离子行动 ...

    fishbowl_api:Fishbowl Ionic 应用程序的 API 和服务器逻辑。 Ruby 通过 Sinatra

    2. **Ionic应用程序**:Fishbowl API 与 Ionic 应用程序配合工作,Ionic 是一个开源框架,用于构建高性能的跨平台移动应用。它基于 Angular 并利用 Cordova 或 Capacitor 来原生打包应用。API 提供后端服务,而 ...

    timesheet-tracker:基于Ionic框架构建的移动应用程序,可跟踪JIRA中开发人员记录的时间

    开发者需要对OAuth2认证流程有深入了解,以确保安全地获取和刷新访问令牌。 5. **移动应用开发**:在Ionic框架下,开发者可以利用Cordova插件访问设备的原生功能,如相机、通知、本地存储等。在"timesheet-tracker...

    为wordpress博客开发移动应用安卓IOS小程序开发中

    应用需要处理用户的登录和注册功能,可以利用WordPress的OAuth2插件或JWT(JSON Web Tokens)实现安全的用户认证。这允许用户直接使用他们的WordPress账号登录移动应用。 6. **界面设计与适配**: 移动应用的界面...

    bookstore-manager:自动化专业,环境友好型专业竞赛,RESTful,Spring Boot,JWT,Spring Security

    【描述】提到的"Projeto Udemy"表明这是一个在Udemy平台上学习和实践的项目,涵盖了Spring Boot、Hibernate、REST技术,以及前端的Ionic框架。此外,项目还涉及到了AWS S3存储服务和MySQL数据库,构建了一个完整的...

    heroku-spring-boot-test1:Heroku 的 Spring Boot 测试

    heroku-spring-boot-test1 Heroku 的 Spring Boot 测试。 使用 Heroku 测试部署 REST Api。... 这是对使用 REST API 调用和 ionic 框架的移动应用程序的测试。 该项目从一无所有开始,但使用了来自不同或一些元素。

    在线搜索音乐播放器源码PC+WAP移动端

    - **RESTful API**: 设计遵循REST原则的接口,使得前后端数据交换更加规范和高效。 3. **数据库**: - **MySQL/MongoDB**: 存储音乐信息,如歌曲ID、歌手、专辑、歌词等。可能采用关系型数据库MySQL或非关系型...

    leshop

    2. **Hibernate**: Hibernate是一个Java ORM(对象关系映射)框架,它允许开发者用面向对象的方式来处理数据库操作。Hibernate自动处理SQL语句,提供了一种简便的方法来管理数据库事务,提高了开发效率。 3. **REST...

    高仿美团点单流程

    - RESTful API 设计:遵循REST原则,定义清晰的API接口,如GET用于获取信息,POST用于创建新订单,PUT用于更新订单状态,DELETE用于取消订单。 3. 数据库设计: - MySQL/PostgreSQL/MongoDB:选择适合的数据库...

    virtual-store-API:使用技术创建虚拟商店的API剩余部分的项目

    API采用REST(Representational State Transfer)架构风格,遵循HTTP协议,提供了CRUD(创建、读取、更新、删除)操作。每个资源都有一个唯一的URI(统一资源标识符),通过HTTP方法(GET、POST、PUT、DELETE)进行...

    MyDiary:带有Kinvey RESTful API的离子日记应用

    2. **Kinvey后端即服务平台(Backend-as-a-Service, BaaS)**: Kinvey是一个强大的BaaS提供商,提供RESTful API供客户端应用进行数据操作。在本项目中,Kinvey为"MyDiary"提供了数据存储、用户认证和同步功能,...

    OctoMobile:OctoPrint 移动客户端

    2. **WebSocket**:为了实现实时的打印机状态更新,OctoMobile可能使用WebSocket协议,这是一种在浏览器和服务器之间建立长连接的技术,可以双向通信,提供实时性。 3. **响应式设计**:由于目标平台包括不同尺寸和...

Global site tag (gtag.js) - Google Analytics