import Vue from 'vue' import { axios } from '@/utils/request' import signMd5Utils from '@/utils/encryption/signMd5Utils' const api = { user: '/mock/api/user', role: '/mock/api/role', service: '/mock/api/service', permission: '/mock/api/permission', permissionNoPager: '/mock/api/permission/no-pager' } export default api //post export function postAction(url,parameter) { let sign = signMd5Utils.getSign(url, parameter); //将签名和时间戳,添加在请求接口 Header let signHeader = {"X-Sign": sign,"X-TIMESTAMP": signMd5Utils.getDateTimeToString()}; return axios({ url: url, method:'post' , data: parameter, headers: signHeader }) } //post method= {post | put} export function httpAction(url,parameter,method) { let sign = signMd5Utils.getSign(url, parameter); //将签名和时间戳,添加在请求接口 Header let signHeader = {"X-Sign": sign,"X-TIMESTAMP": signMd5Utils.getDateTimeToString()}; return axios({ url: url, method:method , data: parameter, headers: signHeader }) } //put export function putAction(url,parameter) { return axios({ url: url, method:'put', data: parameter }) } //get export function getAction(url,parameter) { let sign = signMd5Utils.getSign(url, parameter); //将签名和时间戳,添加在请求接口 Header let signHeader = {"X-Sign": sign,"X-TIMESTAMP": signMd5Utils.getDateTimeToString()}; return axios({ url: url, method: 'get', params: parameter, headers: signHeader }) } //deleteAction export function deleteAction(url,parameter) { return axios({ url: url, method: 'delete', params: parameter }) } export function getUserList(parameter) { return axios({ url: api.user, method: 'get', params: parameter }) } export function getRoleList(parameter) { return axios({ url: api.role, method: 'get', params: parameter }) } export function getServiceList(parameter) { return axios({ url: api.service, method: 'get', params: parameter }) } export function getPermissions(parameter) { return axios({ url: api.permissionNoPager, method: 'get', params: parameter }) } // id == 0 add post // id != 0 update put export function saveService(parameter) { return axios({ url: api.service, method: parameter.id == 0 ? 'post' : 'put', data: parameter }) } /** * 下载文件 用于excel导出 * @param url * @param parameter * @returns {*} */ export function downFile(url,parameter){ return axios({ url: url, params: parameter, method:'get' , responseType: 'blob' }) } /** * 下载文件 * @param url 文件路径 * @param fileName 文件名 * @param parameter * @returns {*} */ export function downloadFile(url, fileName, parameter) { return downFile(url, parameter).then((data) => { if (!data || data.size === 0) { Vue.prototype['$message'].warning('文件下载失败') return } if (typeof window.navigator.msSaveBlob !== 'undefined') { window.navigator.msSaveBlob(new Blob([data]), fileName) } else { let url = window.URL.createObjectURL(new Blob([data])) let link = document.createElement('a') link.style.display = 'none' link.href = url link.setAttribute('download', fileName) document.body.appendChild(link) link.click() document.body.removeChild(link) //下载完成移除元素 window.URL.revokeObjectURL(url) //释放掉blob对象 } }) } /** * 文件上传 用于富文本上传图片 * @param url * @param parameter * @returns {*} */ export function uploadAction(url,parameter){ return axios({ url: url, data: parameter, method:'post' , headers: { 'Content-Type': 'multipart/form-data', // 文件上传 }, }) } /** * 获取文件服务访问路径 * @param avatar * @param subStr * @returns {*} */ export function getFileAccessHttpUrl(avatar,subStr) { if(!subStr) subStr = 'http' try { if(avatar && avatar.startsWith(subStr)){ return avatar; }else{ if(avatar && avatar.length>0 && avatar.indexOf('[')==-1){ return window._CONFIG['staticDomainURL'] + "/" + avatar; } } }catch(err){ return; } }