跳到主要內容

GAE using Objectify

Objectify是GAE Java的一個lightware IoC framework
透過Objectify可以達到與Spring相似的IoC功能
下面是操作Objectify的一些過程:

Step1: Download Objectify library

本文下載的是objectify 3.1版本的

Step2: Create Entity class

Objectify是針對Entity Object來進行資料的存取動作,因此需要先建立Car的Entity類別

package com.mitac.objectify;
import javax.persistence.Entity;
import javax.persistence.Id;
@Entity
public class Car {
    @Id 
    String idx; // Can be Long, long, or String
    
    String name;
    
    public Car(String idx, String name) {
    this.idx = idx;
    this.name = name;
    }
}
  
Step3: Create service middleware

建立static class的middleware來作為呼叫Objectify的中介

package com.mitac.objectify;
import com.googlecode.objectify.Objectify;
import com.googlecode.objectify.ObjectifyFactory;
import com.googlecode.objectify.ObjectifyService;
public class OfyService {
    static {
        factory().register(Car.class);
        //... etc
    }
    public static Objectify ofy() {
        return ObjectifyService.begin();
    }
    public static ObjectifyFactory factory() {
        return ObjectifyService.factory();
    }
}

Step4: Using middleware to put data

package com.mitac.objectify;
import static com.mitac.objectify.OfyService.ofy;
import java.io.IOException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@SuppressWarnings("serial")
public class GaeObjectifyServlet extends HttpServlet {
public void doGet(HttpServletRequest req, HttpServletResponse resp)
throws IOException {

ofy().put(new Car("audi", "audi a3"));
Car car = ofy().get(Car.class, "audi");

resp.setContentType("text/plain");
resp.getWriter().println("Hello, world ==> " + car.name );
}
}

Other: Query example

查詢的方式跟Low Level API差不多,範例如下:

Query<Car> query = ofy().query(Car.class);
query.filter("name = ", "audi a3").order("name");
List<Car> cars = query.list();
Iterator iter = cars.iterator();
while(iter.hasNext()) {
    Car c = (Car) iter.next();
    out.println("Hello, world ==> " + c.name );
}

參考文獻:

留言

這個網誌中的熱門文章

Share a chrome plugin for manage google cloud platform

好玩意兒報報.... 同事的新作,把Google Project List在Chrome Plugin中! 對一次管理多個專案的人來說,真得超方便的拉! 下載: https://chrome.google.com/webstore/detail/gdclauncher/bicgkglnnilldakpenngnblekooejnpg 使用說明: 1. Use browser url bar to quick search: Type "gdcl" in browser Press "TAB" to start search Type the project id key word then select the search result... 2. Using quick launch bar... You can search by keyword or click project name to go to the project or gae link to go to gae or go to billing page....

透過Google Apps Script結合Google Form做即時郵件通知

體驗過Google Apps Script的功能後,也發現他結合GmailApps的模組 GmailApps的應用可以用在表單填寫完成後,做發信的通知 例如您開立了一個訂購的表單,為了要在第一時間通知商家有訂單進入 就可以直接呼叫Gmail做發信的通知,讓手持Smart Phone的我們可以很快的知道生意上門了! 下面規劃三個function,其中: onCommit():為form commit時候觸發的function,需要掛載於form commit trigger上 jsonArrToTable():目的將json array解析成為一個Table getLastRowTable():目的將整個table的回傳過濾為剩下第一筆(表頭,含有Form的欄位說明)與最後一筆(原則上就是剛剛送出的那一筆表單) 完整程式碼如下: function onCommit(){   var sheet = SpreadsheetApp.getActiveSheet();   var rows = sheet.getDataRange();   var numRows = rows.getNumRows();   var values = rows.getValues();   var content = getLastRowTable(values);   var htmlBody = "Hi Admin: <br/><br/>有訂單拉,檢查一下吧! <br/><br/>" + content + '<br/><br/>Send by Google Apps';   GmailApp.sendEmail(     " your-email-address@gmail.com ",      "Order Confirm Notice",      htmlBody,      {from: ' from-email-...

Cloud Monitor嚐鮮

GCP上,我們非常想要的一個功能,終於問世.... Cloud Monitor來了!