Baidu コンテンツ レビュー インターフェイス テスト
1. 開発者になる
アカウントの基本登録と認証を完了するための 3 つのステップ:
STEP1: Baidu AI Open Platform Navigationの右側にあるコンソールをクリックし、使用するAIサービス項目を選択します。ログインしていない場合は、ログイン インターフェイスにリダイレクトされます。Baidu アカウントでログインしてください。Baidu アカウントをまだお持ちでない場合は、ここをクリックしてBaidu アカウントに登録できます。
STEP2 : 初めてご利用になる場合は、ログイン後、開発者認定ページに移動します。関連情報を入力して開発者認定を完了してください。注: (すでに Baidu Cloud ユーザーまたは Baidu Developer Center ユーザーである場合は、この手順はスキップできます)。
ステップ 3 : コンソールの左側にあるナビゲーションで、[製品サービス] - [人工知能] を選択し、特定の AI サービス項目 (テキスト認識、顔認識など) のコントロール パネルに入り、関連するビジネス操作を実行します。
2. アプリケーションを作成する
アカウントのログインが成功したら、AI 機能を正式に呼び出すアプリケーションを作成する必要があります。アプリケーションは、API サービスを呼び出すための基本的な操作単位であり、アプリケーションの作成後に取得した API キーとシークレット キーに基づいて、インターフェイスの呼び出し操作と関連する設定を実行できます。
クリックして入力してください
必要な情報を取得します。
アプリID:
351165xx
APIキー:
vUPhwzKPAyYxgOxxx
秘密鍵:
X6qYI3Vf43pjaELCIpXTHKvGxxxx
3. 監査コードの実装:
依存関係を追加します。
<!-- 百度的api 依赖 -->
<dependency>
<groupId>com.baidu.aip</groupId>
<artifactId>java-sdk</artifactId>
<version>4.8.0</version>
</dependency>
<!-- 网络请求的依赖 -->
<dependency>
<groupId>com.squareup.okhttp3</groupId>
<artifactId>okhttp</artifactId>
<version>4.9.3</version>
</dependency>
画像レビューコード:
public class Demo01 {
public static final String API_KEY = "vUPhwzKPAyYxgOx7e8xxx";
public static final String SECRET_KEY = "X6qYI3Vf43pjaELCIpXTHKvGxxx";
static final OkHttpClient HTTP_CLIENT = new OkHttpClient().newBuilder().build();
public static void main(String []args) throws IOException{
MediaType mediaType = MediaType.parse("application/x-www-form-urlencoded");
// image 可以通过 getFileContentAsBase64("C:\fakepath\q.jpeg") 方法获取,如果Content-Type是application/x-www-form-urlencoded时,第二个参数传true
String path = "C:\\pic\\手枪.jpeg";
String image = "image=" + getFileContentAsBase64(path, true);
RequestBody body = RequestBody.create(image,mediaType);
Request request = new Request.Builder()
.url("https://aip.baidubce.com/rest/2.0/solution/v1/img_censor/v2/user_defined?access_token=" + getAccessToken())
.method("POST", body)
.addHeader("Content-Type", "application/x-www-form-urlencoded")
.addHeader("Accept", "application/json")
.build();
Response response = HTTP_CLIENT.newCall(request).execute();
System.out.println(response.body().string());
}
/**
* 获取文件base64编码
*
* @param path 文件路径
* @param urlEncode 如果Content-Type是application/x-www-form-urlencoded时,传true
* @return base64编码信息,不带文件头
* @throws IOException IO异常
*/
static String getFileContentAsBase64(String path, boolean urlEncode) throws IOException {
byte[] b = Files.readAllBytes(Paths.get(path));
String base64 = Base64.getEncoder().encodeToString(b);
if (urlEncode) {
base64 = URLEncoder.encode(base64, "utf-8");
}
return base64;
}
/**
* 从用户的AK,SK生成鉴权签名(Access Token)
*
* @return 鉴权签名(Access Token)
* @throws IOException IO异常
*/
static String getAccessToken() throws IOException {
MediaType mediaType = MediaType.parse("application/x-www-form-urlencoded");
RequestBody body = RequestBody.create("grant_type=client_credentials&client_id=" + API_KEY
+ "&client_secret=" + SECRET_KEY,mediaType);
Request request = new Request.Builder()
.url("https://aip.baidubce.com/oauth/2.0/token")
.method("POST", body)
.addHeader("Content-Type", "application/x-www-form-urlencoded")
.build();
Response response = HTTP_CLIENT.newCall(request).execute();
return new JSONObject(response.body().string()).getString("access_token");
}
}
操作結果:
{
"conclusion": "疑似",
"log_id": 16873337141692598,
"data": [{
"msg": "疑似存在枪械不合规",
"conclusion": "疑似",
"probability": 0.88919306,
"subType": 11,
"conclusionType": 3,
"type": 2
}],
"isHitMd5": false,
"conclusionType": 3
}
テキストレビューコード:
public class Demo02 {
public static final String API_KEY = "vUPhwzKPAyYxgOx7xxx";
public static final String SECRET_KEY = "X6qYI3Vf43pjaELCIpXTHKvxxx";
static final OkHttpClient HTTP_CLIENT = new OkHttpClient().newBuilder().build();
public static void main(String []args) throws IOException{
String msg = "text=傻x";
String decode = URLDecoder.decode(msg, "utf-8");
MediaType mediaType = MediaType.parse("application/x-www-form-urlencoded");
RequestBody body = RequestBody.create(msg,mediaType);
Request request = new Request.Builder()
.url("https://aip.baidubce.com/rest/2.0/solution/v1/text_censor/v2/user_defined?access_token=" + getAccessToken())
.method("POST", body)
.addHeader("Content-Type", "application/x-www-form-urlencoded")
.addHeader("Accept", "application/json")
.build();
Response response = HTTP_CLIENT.newCall(request).execute();
System.out.println(response.body().string());
}
/**
* 从用户的AK,SK生成鉴权签名(Access Token)
*
* @return 鉴权签名(Access Token)
* @throws IOException IO异常
*/
static String getAccessToken() throws IOException {
MediaType mediaType = MediaType.parse("application/x-www-form-urlencoded");
RequestBody body = RequestBody.create(mediaType, "grant_type=client_credentials&client_id=" + API_KEY
+ "&client_secret=" + SECRET_KEY);
Request request = new Request.Builder()
.url("https://aip.baidubce.com/oauth/2.0/token")
.method("POST", body)
.addHeader("Content-Type", "application/x-www-form-urlencoded")
.build();
Response response = HTTP_CLIENT.newCall(request).execute();
return new JSONObject(response.body().string()).getString("access_token");
}
}
操作結果:
{
"conclusion": "不合规",
"log_id": 16873336469633031,
"data": [{
"msg": "存在低俗辱骂不合规",
"conclusion": "不合规",
"hits": [{
"wordHitPositions": [{
"positions": [
[0, 1]
],
"label": "500100",
"keyword": "傻x"
}],
"probability": 1.0,
"datasetName": "百度默认文本反作弊库",
"words": ["傻x"],
"modelHitPositions": [
[0, 1, 1.0]
]
}],
"subType": 5,
"conclusionType": 2,
"type": 12
}],
"isHitMd5": false,
"conclusionType": 2
}