一、学习笔记
HarmonyOS NEXT API 12
二、代码实例
class FileUtils {
/**
* 从文件路径获取文件名
* @param filePath 文件路径
* @returns
*/
getFileName(filePath:string):string{
const parts = filePath.split('/');
const fileName = parts[parts.length - 1];
return fileName
}
/**
* 创建目录
* @param path 目录路径
*/
creatFolder(path: string){
if(!fs.accessSync(path)){
fs.mkdirSync(path) // 同步创建
}
}
/**
* 删除文件夹、文件
* @param path 路径
*/
deleteFile(path: string){
if(!fs.accessSync(path)){
// 文件不存在
return
}
if(fs.statSync(path).isDirectory()){
fs.rmdirSync(path) // 同步删除
}else {
fs.unlinkSync(path) // 同步删除
}
}
/**
* 目录名规范校验
* @param name
* @returns
*/
isValidDirectoryName(name: string): boolean {
// 规则:
// 1. 名称长度必须在 1 到 255 个字符之间。
// 2. 只能包含字母、数字、空格、下划线、连字符和点。
// 3. 不能以点开头或结尾,也不能包含连续的点。
// 4. 不能包含操作系统保留的关键词(这里省略具体实现,因为需要特定于操作系统)
const minLength = 1;
const maxLength = 255;
const validChars = /^[a-zA-Z0-9\s_\-.]+$/; // 正则表达式,匹配允许的字符
const startsOrEndsWithDot = /^\.|\.$/; // 正则表达式,匹配以点开头或结尾
const containsConsecutiveDots = /\.{2,}/; // 正则表达式,匹配连续的点
// 检查长度
if (name.length < minLength || name.length > maxLength) {
return false;
}
// 检查字符
if (!validChars.test(name)) {
return false;
}
// 检查以点开头或结尾
if (startsOrEndsWithDot.test(name)) {
return false;
}
// 检查连续的点
if (containsConsecutiveDots.test(name)) {
return false;
}
// 可选:检查保留字(这里省略,因为实现会依赖于操作系统)
// 如果所有检查都通过,则返回 true
return true;
}
// 文件压缩
zipCompress(srcPath: string, desName: string) {
let inFile = srcPath // 源文件路径
let outFile = desName // 压缩到指定路径
let options: zlib.Options = {
level: zlib.CompressLevel.COMPRESS_LEVEL_BEST_COMPRESSION,
memLevel: zlib.MemLevel.MEM_LEVEL_DEFAULT,
strategy: zlib.CompressStrategy.COMPRESS_STRATEGY_DEFAULT_STRATEGY
}
if (!fs.accessSync(inFile)) {
// 文件不存在
return
}
zlib.compressFile(inFile, outFile, options).then((data: void) => {
AppLogger.debug('压缩成功')
}).catch((errData: BusinessError) => {
AppLogger.error(`压缩出错 errCode:${errData.code} message:${errData.message}`)
})
}
}
export default new FileUtils();