美文网首页
v002-HarmonyOS(arkTS)常用功能整理

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

作者: 刘坤林 | 来源:发表于2024-06-14 11:31 被阅读0次

一、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)}`)
    }
  }
}

相关文章

  • Pandas 常用功能整理

    1.Create DataFrame df=pd.DataFrame([Series1,Series2],inde...

  • python之os/os.path模块常备技能

    os是写脚本的常用功能,主要用于文件操作,路径操作, 常用的命令整理如下,只是常用并非全部

  • iOS开发常用功能整理

    此文纯为自己备忘,不喜勿喷,默默关掉! 1.改变状态栏颜色 (1)在info.plist文件中改 (2)代码更改 ...

  • AWK常用功能个人整理

    awk 功能比sed更加强大,但表达式会相对复杂一些 首先说明几个比较重要的内置参数 1.输出特定行 指定分隔符 ...

  • Sed常用功能个人整理

    Sed对1G以下的数据效率很高这里介绍一些个人在工作中遇到的sed问题 1.查找字段 以文章test.txt为例:...

  • 简书常用功能整理

    来到简书后发现一些朋友对简书的一些基础功能还不够了解,希望这篇文章能帮助大家尽快摸清这些功能的用法。 一.简书设置...

  • 自动化工具

    Postman功能更完整,也更合适用于团队合作开发,以下是整理的几个重要常用功能,但是功能远不止这些。 创建Htt...

  • 整理记录App开发常用功能

    1.网络请求安全性 目的 确保接口都是合法的被访问,而不是外部人员通过接口测试工具(例如postman)进行访问。...

  • 项目管理工具1: Excel常用操作整理

    Excel是项目管理常用基础工具之一,具有无限的可拓展能力。以下是Excel一些常用重要功能、技巧整理;后期如果用...

  • springboot项目编写 SDK、组件自动扫描、HTTP请求

    本文章整理一些本人日常常用小功能技巧,会持续更新,目前包含以下功能 SDK 的生成以及 deploy 过滤不需要...

网友评论

      本文标题:v002-HarmonyOS(arkTS)常用功能整理

      本文链接:https://www.haomeiwen.com/subject/txqaqjtx.html