Anda sedang melihat dokumentasi Apigee Edge.
Buka
dokumentasi Apigee X. info
Apa yang dimaksud dengan info Java?
Jika Anda baru mengenal info Java, sebaiknya mulai dengan Cara membuat info Java.
Menggunakan properti dalam info Java
Properti memungkinkan Anda menentukan pasangan nama/nilai dalam kebijakan info Java yang dapat Anda akses dari kode Java saat runtime. Anda harus menentukan nilai string literal untuk setiap properti; Anda tidak dapat mereferensikan variabel alur dalam elemen ini.
Mari kita lihat contoh info Java sederhana yang menggunakan properti. Dalam contoh ini, kami
membuat proxy yang menyertakan kebijakan info Java. Kebijakan ini menggunakan elemen
<Properties>
untuk menentukan pasangan nama/nilai. Dalam kode Java, kita
mengambil nilai tersebut dan menggunakannya untuk menetapkan header respons.
Mendownload project
Untuk mempermudah, Anda dapat mendownload project ini dari repositori api-platform-samples Apigee di GitHub.
- Download atau clone api-platform-samples ke sistem Anda.
- Di terminal atau editor kode pilihan Anda, buka
project
api-platform-samples/doc-samples/java-properties
.
Kebijakan info Java
Kebijakan ini menggunakan elemen <Properties>
. Elemen ini memungkinkan Anda menentukan pasangan nama/nilai. Saat runtime, kode Java Anda dapat mengakses nilai properti yang ditentukan dalam
kebijakan, seperti yang akan kita lihat sebentar lagi.
<JavaCallout name="java-callout"> <ClassName>com.apigeesample.JavaProperties</ClassName> <ResourceURL>java://edge-custom-policy-java-properties.jar</ResourceURL> <Properties> <Property name="prop">WORLD!</Property> </Properties> </JavaCallout>
Contoh kode Java
Kode Java untuk contoh ini menunjukkan cara mengambil properti yang ditentukan dalam
kebijakan info Java. Dalam project contoh, Anda dapat menemukan kode sumber di
java-properties/callout/src/main/java/JavaProperties.java
. Kami akan memandu
langkah-langkah mengompilasi dan men-deploy kode ini nanti dalam topik ini.
package com.apigeesample; import com.apigee.flow.execution.ExecutionContext; import com.apigee.flow.execution.ExecutionResult; import com.apigee.flow.execution.spi.Execution; import com.apigee.flow.message.MessageContext; import java.util.Map; public class JavaProperties implements Execution { private Map <String,String> properties; // read-only public JavaProperties(Map <String,String> properties) { this.properties = properties; } public ExecutionResult execute(MessageContext messageContext, ExecutionContext executionContext) { try { messageContext.getMessage().setHeader("X-PROPERTY-HELLO", this.properties.get("prop")); return ExecutionResult.SUCCESS; } catch (Exception e) { return ExecutionResult.ABORT; } } }
Mengompilasi kode dengan Maven
Project sudah disiapkan agar Anda dapat mengompilasi dengan Maven. Jika Anda ingin menggunakan
javac
, kami juga akan menyertakan contoh.
- Pastikan Anda telah menginstal Maven:
mvn -version
- Jalankan skrip
java-properties/buildsetup.sh
. Skrip ini akan menginstal dependensi JAR yang diperlukan dalam repo Maven lokal Anda. - {i>cd<i} ke direktori
java-properties/callout
. - Jalankan Maven:
mvn clean package
- Jika mau, pastikan bahwa file JAR
edge-custom-policy-java-properties.jar
disalin kejava-properties/apiproxy/resources/java
. Ini adalah lokasi yang diperlukan untuk file JAR yang ingin Anda deploy dengan proxy.
Mengompilasi dengan javac (opsional)
Jika ingin menggunakan javac
untuk mengompilasi kode, Anda dapat melakukan sesuatu yang mirip dengan berikut ini (dari direktori java-properties
). File JAR yang diperlukan disediakan
untuk Anda di direktori java-properties/lib
.
- {i>cd<i} ke
api-platform-samples/doc-samples/java-properties
. - Pastikan Anda memiliki javac di jalur Anda.
javac -version
- Jalankan perintah javac berikut:
javac -d . -classpath ./lib/expressions-1.0.0.jar:./lib/message-flow-1.0.0.jar:. callout/src/main/java/JavaProperties.java
- Buat file JAR:
jar -cvf edge-custom-policy-java-properties.jar ./com/apigeesample/JavaProperties.class
- Salin file JAR ke direktori apiproxy/resources/java. Ini adalah lokasi yang diperlukan
untuk file JAR yang ingin Anda deploy dengan proxy.
cp edge-custom-policy-java-properties.jar apiproxy/resources/java
Men-deploy dan memanggil proxy
Skrip deployment disediakan di direktori ./java-properties
. Namun, sebelum menjalankannya, Anda perlu melakukan penyiapan cepat.
- cd ke
api-platform-samples/doc-samples/java-properties
- Jika Anda belum melakukannya, buka file
../../setup/setenv.sh
dan edit file tersebut seperti yang ditunjukkan dengan informasi akun Apigee Anda: nama pengguna (alamat email yang terkait dengan akun Anda), nama organisasi, dan domain yang Anda gunakan untuk melakukan panggilan pengelolaan API. Misalnya, untuk Edge cloud, domainnya adalahhttps://api.enterprise.apigee.com
; namun, domain Anda mungkin berbeda jika Anda menggunakan Edge Private Cloud. - Simpan file
setenv.sh
. - Jalankan skrip deployment:
./deploy.sh
- Jika deployment berhasil, jalankan skrip pemanggilan:
./invoke.sh
Skrip pemanggilan memanggil perintah cURL yang terlihat seperti ini:
curl http://$org-$env.$api_domain/java-properties
Proxy akan menampilkan header:
X-PROPERTY-HELLO: WORLD!
. Ingat bahwa dalam kebijakan, kami menambahkan pasangan nama/nilai properti"prop/WORLD!"
. Info Java mengambil nilai"WORLD!"
dan menetapkannya dalam header bernamaX-PROPERTY-HELLO
:messageContext.getMessage().setHeader("X-PROPERTY-HELLO", this.properties.get("prop"));