v002-HarmonyOS(arkTS)常用功能整理

一、axios网络请求工具类封装

  • 导入相关的库

ohpm install @ohos/axios
  • 请记得添加权限,位置E:*\你的项目\entry\src\main\module.json5**
ohos.permission.INTERNET
  • 如果用到加密方法,那也要导入一下"crypto-js"
ohpm install @ohos/crypto-js
  • 封装方法

import axios, { AxiosError, AxiosResponse } from '@ohos/axios';
import { LogUtils } from '../utils/LogUtils';
import { JSON } from '@kit.ArkTS';
import { CallResult } from '../bean/CallResult';
import { http } from '@kit.NetworkKit';
import { KEY_TOKEN, ShareUtils } from '../utils/ShareUtils';
import { LoginUtils } from '../utils/LoginUtils';

/**
 * 默认请求时长
 */
const DEFAULT_TIMEOUT = 1000 * 20;
/**
 * 默认地址
 */
const Url = 'http://192.168.1.221:880';
axios.defaults.baseURL = 'http://192.168.1.221:880';
axios.defaults.headers.post['Content-Type'] = 'application/json';

export class UrlUtils {
  /**
   * token值
   */
  static TOKEN: string = LoginUtils.getToken();

  public static setSaveToken(token: string) {
    UrlUtils.TOKEN = token;
    ShareUtils.set(KEY_TOKEN, token)
  }

  static get<T>(apiPath: string): Promise<CallResult<T>> {
    return axios<string, AxiosResponse<CallResult<T>>, null>({
      baseURL: Url,
      url: apiPath,
      timeout: DEFAULT_TIMEOUT,
      method: http.RequestMethod.GET,
      headers: {
        'token': UrlUtils.TOKEN
      }
    }).then((resp: AxiosResponse<CallResult<T>>) => {
      UrlUtils.logInfo(apiPath, undefined, resp.data);
      return resp.data;
    }).catch((error: AxiosError) => {
      let data: CallResult<T> = new CallResult<T>()
      data.code = 400
      data.message = error.message
      UrlUtils.logInfo(apiPath, undefined, data);
      return data;
    })
  }

  static post<T>(apiPath: string, params: object): Promise<CallResult<T>> {
    return axios<string, AxiosResponse<CallResult<T>>, object>({
      baseURL: Url,
      url: apiPath,
      timeout: DEFAULT_TIMEOUT,
      method: http.RequestMethod.POST,
      headers: {
        'token': UrlUtils.TOKEN
      },
      data: params,
    }).then((resp: AxiosResponse<CallResult<T>>) => {
      UrlUtils.logInfo(apiPath, params, resp.data);
      return resp.data;
    }).catch((error: AxiosError) => {
      let data: CallResult<T> = new CallResult<T>()
      data.code = 400
      data.message = error.message
      UrlUtils.logInfo(apiPath, params, data);
      return data;
    })
  }

  private static logInfo<T>(apiPath: string, params?: object, data?: CallResult<T>) {
    LogUtils.i("请求地址:" + Url + apiPath)
    if (params != null) {
      LogUtils.i("请求参数:" + JSON.stringify(params))
    }
    if (data != null) {
      LogUtils.i("返回参数:" + JSON.stringify(data))
    }
  }
}
  • 使用方法

  • post方法
let record: Record<string, string> = {
      "phone": this.phone,
      "passWord": ValueUtils.md5(this.pwd)
    }
    let apiPath = '/api/sysuser/login'
    UrlUtils.post<LoginResp>(apiPath, record).then(data => {
      if (data.code == 200 && data.data != null) {
        UrlUtils.setSaveToken(data.data.token)
        ShareUtils.set('userName', data.data.userName);
        router.replaceUrl({ url: 'pages/MainPage' })
      } else {
        ComUtils.toast(data.message)
      }
    })
  • get方法
     UrlUtils.get<UserInfoBean>('/api/sysuser/info').then(data => {
      if (data.code == 200) {
        LogUtils.i("用户信息:" + JSON.stringify(data.data))
      }
    })

二、首选项

  • 封装方法

import { preferences } from '@kit.ArkData';
import { LogUtils } from './LogUtils';

//数据库名称
const LuckDataBase: string = 'LuckDataBase1';

//token名称
export const KEY_TOKEN: string = "Luck_KEY_TOKEN";

export class ShareUtils {
  static options: preferences.Options = { name: LuckDataBase }
  static dataPreferences: preferences.Preferences;

  private static getPreference() {
    if (ShareUtils.dataPreferences == null) {
      ShareUtils.dataPreferences = preferences.getPreferencesSync(getContext(), ShareUtils.options)
    }
    return ShareUtils.dataPreferences;
  }

  static set(key: string, value: string) {
    let dataPreferences = ShareUtils.getPreference();
    dataPreferences.putSync(key, value)
    dataPreferences.flush()
    LogUtils.i(`保存成功:${key},${value}`)
  }

  static remove(key: string) {
    let dataPreferences = ShareUtils.getPreference();
    dataPreferences.deleteSync(key)
  }

  static getString(key: string) {
    let dataPreferences = ShareUtils.getPreference();
    return dataPreferences.getSync(key, '').toString()
  }
}
  • 使用方法

  //保存数据
  ShareUtils.set('userName', data.data.userName);
  //读取数据
  ShareUtils.getString(KEY_TOKEN)

三、其他,如吐司、自定义实体类泛型,日志工具类等

  • 吐司

import promptAction from '@ohos.promptAction';

export default class ComUtils {
  static toast(message: Resource | string) {
    promptAction.showToast({
      message: message,
      duration: 1500
    });
  };
}
//使用方法
ComUtils.toast("请输入密码")
  • 自定义实体类泛型

/**
 * https://developer.huawei.com/consumer/cn/forum/topic/0204148819047359327?fid=0102683795438680754
 * 如果你的class是new出来的,那么方法可用,如果是通过赋值过来的,那么就不可用。
 */
export class CallResult<T> {
  /**
   * 服务器返回的code,为200则请求成功
   */
  code: number;
  /**
   * 服务器返回的回调消息
   */
  message: string;
  /**
   * 指定的泛型
   */
  data?: T;

  constructor() {
    this.code = 0;
    this.message = '';
  }
  static isSuccess<T>(data: CallResult<T>) {
    return data.code == HttpStatusCode.Ok;
  }

  static isSuccessAndNotNull<T>(data: CallResult<T>) {
    return this.isSuccess(data) && data.data != null;
  }
}
  • 日志工具类

export default class LogUtils {
  private static TAG: string = "excc";

  static i(info: any): void {
    if(info==null || info == undefined){
      return
    }
    if (info instanceof Number || info instanceof String || info instanceof Boolean) {
      console.info(`${this.TAG}:${info}`)
    } else {
      console.info(`${this.TAG}:${JSON.stringify(info)}`)
    }
  }

  static e(error: any): void {
    if(error==null || error == undefined){
      return
    }
    if (error instanceof Number || error instanceof String || error instanceof Boolean) {
      console.error(`${this.TAG}:${error}`)
    } else {
      console.error(`${this.TAG}:${JSON.stringify(error)}`)
    }
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339