これは本当にイライラします。API キーを問題なく使用しています。認証は問題なく行われ、トークンは問題なく生成され、セッション キーも問題ありません。
しかし、を実行するplaylist.create
と、プレイリストが作成されません。
今日はほぼゼロから始めて、ほとんどのコードをやり直しました。16 個のプレイリストを正常に作成しました。エラーはありません。しかし、今日、同じコードが機能していません。まったく触れていませんが、エラーです。
private static void buildPlaylist() {
String mood = "Happy";
System.out.println("\nMood is " + mood + "\n\n");
String title = URLEncoder.encode(mood + " " + new Date().getTime(), "UTF-8");
String description = URLEncoder.encode("For when you are " + mood + ". Created by MoodicPlayer.", "UTF-8");
MessageDigest md = MessageDigest.getInstance("MD5");
String apiSig = "api_key" + key + "description" + description + "methodplaylist.createsk" + sessionKey + "title" + title + secret;
md.update(apiSig.getBytes());
byte byteData[] = md.digest();
//convert the byte to hex format
StringBuffer sb = new StringBuffer();
for (int i = 0; i < byteData.length; i++) {
sb.append(Integer.toString((byteData[i] & 0xff) + 0x100, 16).substring(1));
}
String hashedSig = sb.toString();
// FOR DEBUGGING
System.out.println("api_key = " + key);
System.out.println("api_sig = " + hashedSig);
System.out.println("session key = " + sessionKey);
// FOR DEBUGGING
String urlParameters = "method=playlist.create&api_key="+ key + "&api_sig=" + hashedSig + "&description=" + description + "&sk=" + sessionKey + "&title=" + title;
String request = "http://ws.audioscrobbler.com/2.0/";
URL url = new URL(request);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setDoOutput(true);
connection.setDoInput(true);
connection.setInstanceFollowRedirects(false);
connection.setRequestMethod("POST");
connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
connection.setRequestProperty("charset", "utf-8");
connection.setRequestProperty("Content-Length", "" + Integer.toString(urlParameters.getBytes().length));
connection.setUseCaches(false);
DataOutputStream wr = new DataOutputStream(connection.getOutputStream());
wr.writeBytes(urlParameters);
wr.flush();
wr.close();
InputStream is = null;
Scanner s = null;
try {
if (connection.getResponseCode() != 200) {
s = new Scanner(connection.getErrorStream());
} else {
is = connection.getInputStream();
s = new Scanner(is);
}
s.useDelimiter("\\Z");
String response = s.next();
System.out.println("\nResponse: " + response + "\n\n");
BufferedWriter out = new BufferedWriter(new FileWriter("requestCreate.xml"));
out.write(response);
out.close();
} catch (IOException e2) {
e2.printStackTrace();
}
// FOR DEBUGGING
try {
System.out.println("Response Code: " + connection.getResponseCode());
System.out.println("Response Message: " + connection.getResponseMessage());
} catch (IOException e) {
e.printStackTrace();
}
// FOR DEBUGGING
connection.disconnect();
}
そして出力:
Starting test for creating playlist...
Mood is Happy
api_key = xxxxx
api_sig = xxxxxx
session key = xxxxx
Response: <?xml version="1.0" encoding="utf-8"?>
<lfm status="failed">
<error code="13">
Invalid method signature supplied
</error>
</lfm>
Response Code: 403
Response Message: Forbidden
コードを確認しましたが、エラーは見つかりませんでした。コードは 16 時間前には正常でしたが、突然機能しなくなりました。
セキュリティ上の理由から、セキュリティ キーをお見せすることはできません。ただし、last.fm セッション キーを見つけるための簡単なプログラムを作成しました。 API 呼び出しのテストに必要なものがすべて揃っています。