皋蘭網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項目制作,到程序開發(fā),運營維護。成都創(chuàng)新互聯(lián)成立于2013年到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)。
注意 scope 權(quán)限 , redirect_uri 授權(quán)成功跳轉(zhuǎn)地址, 獲取code, 所有的 auth3 都是這個流程
public String getAuthUrl(Map params0){
String url = Constants.get("login_url") +"/authorize";
url += "?client_id=" + Constants.get("client_id");
url += "&response_type=code";
url += "&redirect_uri=" + Constants.get("redirect_uri");
url += "&scope=offline_access%20Files.ReadWrite.All%20Sites.Read.All%20User.Read";
return url;
}
code是上面獲取到的, 注意 redirect_uri 相同 , client_secret 密鑰, 在建立clientid的地方
獲取到 access_token- 用于api請求的token, expires_in - token過期時間緩存一下, refresh_token-刷新token 用的
public String getToken(Map params0){
String code = params0.get("code");
String url = Constants.get("login_url") +"/token";
HashMap params = new HashMap<>();
params.put("client_id", Constants.get("client_id"));
params.put("redirect_uri", Constants.get("redirect_uri"));
params.put("client_secret", Constants.get("client_secret"));
params.put("code", code);
params.put("grant_type", "authorization_code");
Map resp = OKHttpUtil.post(url, params);;
LogUtil.info("getToken->" + resp);
String token = (String) resp.get("access_token");
int expires_in = (int) resp.get("expires_in") ;
VcodeUtil.timedCache.put("access_token", token, expires_in* 1000);
String refresh_token = (String) resp.get("refresh_token");
VcodeUtil.timedCache.put("refresh_token", refresh_token, expires_in* 1000 * 36);
return token;
}
緩存 access_token 3600秒, 失效后使用 refresh_token 刷新 access_token , refresh_token的 時效較長, 微軟沒有指定具體多久,
測試 至少在 天級別以上
public String getTokenByCache(Map params0){
String token = (String) VcodeUtil.timedCache.getNotUpLastAccess("access_token");
if (token != null) {
return token;
}
String refresh_token = (String) VcodeUtil.timedCache.getNotUpLastAccess("refresh_token");
String url = Constants.get("login_url") +"/token";
HashMap params = new HashMap<>();
params.put("client_id", Constants.get("client_id"));
params.put("scope", "offline_access Files.ReadWrite.All Sites.Read.All User.Read");
params.put("refresh_token", refresh_token);
params.put("redirect_uri", Constants.get("redirect_uri"));
params.put("client_secret", Constants.get("client_secret"));
params.put("grant_type", "refresh_token");
Map resp = OKHttpUtil.post(url, params);;
LogUtil.info("getToken->" + resp);
token = (String) resp.get("access_token");
int expires_in = (int) resp.get("expires_in") ;
VcodeUtil.timedCache.put("access_token", token, expires_in* 1000);
refresh_token = (String) resp.get("refresh_token");
VcodeUtil.timedCache.put("refresh_token", refresh_token, expires_in* 1000 * 36);
return token;
}
//PUT /me/drive/items/{parent-id}:/{filename}:/content , 上傳地址很費解, 這里我做了例子
這樣好理解一點, 使用 絕對路徑上傳, body 直接是文件流
/SEARCH_APP/upload/201912/10/Q5pe5A.jpg 這里是文件路勁
https://graph.microsoft.com/v1.0/me/drive/root:/SEARCH_APP/upload/201912/10/Q5pe5A.jpg:/content
上傳成功后 會返回 這個 item 的信息, 里面有下載地址, 保存這個 id, 和 路徑, 下載的時候提供 itemid 下載方式 和路徑方式
public String upload(String uploadPath, String suffix, ByteArrayOutputStream out) throws Exception{
byte[] bytes = out.toByteArray();
long id = MD5.md5_long(bytes);
Map ins = getIns(id);
if(!ins.isEmpty()) {
return (String) ins.get("itemid");
}
String date = BaseUtil.getFormatDate().replaceFirst("/", "");
uploadPath += date;
String filename = uploadPath + "/" + RandomStringUtils.randomAlphanumeric(6) +"." + suffix;
//PUT /me/drive/items/{parent-id}:/{filename}:/content
String url = "https://graph.microsoft.com/v1.0/me/drive/root:" + filename +":/content";
HttpRequest request = new HttpRequest(url, Method.put);
request.setContentType("image/jpeg");
request.addHeader("Authorization", "Bearer " + getTokenByCache(null));
request.setRequestBody(bytes);
HttpResponse res = OKHttpUtil.request(request);
// 返回的 id 就是 itemid, 可以用此id做一些操作 保存itemid 和 filePath
String resStr= res.getResponseString();
Map resMap = (Map) OKHttpUtil.deserialize(resStr);
String itemid = (String) resMap.get("id");
return itemid;
}
String url = "https://graph.microsoft.com/v1.0/me/drive/items/"+itemid+"/content"; // 下載 按itemid
String url = "https://graph.microsoft.com/v1.0/me/drive/root:" + filepath +":/content"; // 按文件路勁
看代碼, 上面 帶了注釋, 下載地址, 預(yù)覽地址, 和分享地址, 具體實現(xiàn) 看 oneApi, 我都測試過
成功請求后會出現(xiàn) 302 跳轉(zhuǎn), 一般 httpclient 都會自己跳, 不想跳的找配置 獲取Location 可以查看地址
public Object downLoad(Map params) throws Exception{
String itemid = params.get("id");
// String url = "https://graph.microsoft.com/v1.0/me/drive/root:" + filepath +":/content"; // 按文件路勁
// String url = "https://graph.microsoft.com/v1.0/me/drive/items/01RHKEMNKSNBGOHRSDPBHJI43LRLM62MV7/preview"; // 預(yù)覽按itemid
// String url = "https://graph.microsoft.com/v1.0/me/drive/items/01RHKEMNKSNBGOHRSDPBHJI43LRLM62MV7/createLink"; // 分享按itemid
String url = "https://graph.microsoft.com/v1.0/me/drive/items/"+itemid+"/content"; // 下載 按itemid
HttpRequest request = new HttpRequest(url, Method.get);
request.addHeader("Authorization", "Bearer " + getTokenByCache(null));
//request.setContentType("application/json");
//request.setRequestBody("{\"chromeless\":\"true\"}".getBytes());
HttpResponse resp = OKHttpUtil.request(request);
// System.out.println(resp.getResponseString());
// System.out.println(resp.getHeader("Location")); // 302 跳轉(zhuǎn), 自動重新獲取圖片 URL
return resp.getRespInputsStream();
}
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。