Engineering
Keith Donald
November 20, 2010
At SpringOne2gx we announced exciting new initiatives in the areas of social media and mobile application development. A few weeks ago, Craig Walls released Spring Social. Today, Roy Clarkson released Spring Mobile and Spring Android. In this post, I’d like to highlight these projects and share how Spring aims to simplify mobile application development.
Choices in Mobile Application Development
If you attended SpringOne2gx this year, you’ve seen Greenhouse, an app we built for our community that also serves as a reference and driver for Spring technology. Craig showed you some of the social elements of Greenhouse, such as the ability to connect your account with Twitter and Facebook. There are also a number of mobile elements. Specifically, Greenhouse doubles as a mobile web app, and sports native Greenhouse for iPhone and Android clients.
Like many organizations today, we had to answer the basic question of “what mobile platforms to target?” In the end, we chose to invest in a native experience for iPhone and Android users, while also developing a cross-platform mobile web app. Our decision to go native was driven by the fact the app is consumer-oriented, and a large number of prospective consumers (application developers) own iPhone and Android devices. At the same time, the mobile web app aims to provide a good baseline experience that works cross-platform, something that’s possible today with the rise of WebKit and HTML 5.
From our development work, grew Spring Framework contributions: first, a Spring Mobile project that provides extensions to Spring MVC for developing mobile web apps; and second, a Spring Android project that supports the development of native Android clients that communicate with Spring-based back-ends. I’ll take you through each of these projects in turn.
Spring Mobile
The first problem we tackled was designing a web app that was pleasant for mobile visitors to use. While a smartphone may have a capable web browser, it still has a small screen and that needs to be accounted for. There are essentially two approaches to dealing with this problem:
Detect the device that originated the web request and serve a separate site to mobile devices.
Serve a single site, but progressively enhance it for desktop users by using CSS 3 media queries and JavaScript.
You can find examples of both techniques in the wild today; for example, the conference site Lanyrd enhances through client-side detection, while SpeakerRate uses server-side detection that redirects mobile visitors to a separate site (see for yourself by installing the Firefox User Agent Switcher and setting your user agent to iPhone).
In Greenhouse, we started with server-side detection. Specifically, we aimed to apply a different page layout if the device was a mobile device. Out of this grew a general purpose “Device Resolver Abstraction”, which is the defining feature of Spring Mobile 1.0.0.M1. Some highlights of this feature include:
A HandlerInterceptor that uses a DeviceResolver to detect the Device that originated the current HttpServletRequest.
The ability to inject the detected Device into @Controller methods and view templates to vary logic by device type.
Below are some usage examples from the Greenhouse codebase. First, have a look at the interceptor definition from /WEB-INF/spring/appServlet/servlet-context.xml:
Now, a JSP template that conditionally renders some content if the device is not a mobile device:
Please try again<c:if test="${!currentDevice.mobile}"> or <a href="<c:url value="/signup" />">sign up</c:if>.
Finally, a Tiles-based page layout that changes if the device is a mobile device:
<definition name="page" templateExpression="/WEB-INF/layouts/${currentDevice.mobile ? 'mobile/' : 'standard/'}page.jsp" />
In addition to these features, Spring Mobile 1.0.0.M1 ships:
A HandlerInterceptor that redirects mobile visitors to another URL. This is useful if your mobile site truly is a separate application. Consider Flickr, for example, which will redirect you to m.flickr.com if you access www.flickr.com from your phone.
A DeviceResolver implementation that delegates to WURFL for device detection. WURFL provides a large database of devices and their capabilities. It is useful when you need to know more about the Device that originated the request, such as its specific screen size, manufacturer, model, preferred markup, or other capabilities.
Recently, we have also begun exploring the use of CSS 3 media queries with JavaScript to perform client-side detection. This approach has the advantage of not requiring special server-side handling unless you aim to vary the semantic content you send to the device, and not just optimize the style. Not all browsers support media queries, so they may not be an option for you, but if you’re targeting smartphones with WebKit-based browsers you should be fine. In general, the approach of first designing your app for mobile, then progressively enhancing it for desktop feels quite elegant to me.
Spring Android
For the Android client, a different set of challenges emerged. We needed to exchange data with the server over HTTPS via REST, and since that data is user-specific we require the user to sign in. Rather than use Basic Auth, where we would need to store username and password credentials on the device itself, we opted for OAuth.
OAuth is an emerging standard that provides a token-based authorization scheme. Essentially, a username and password is traded for an access token, and the access token is used to make requests for protected resources. This means you only need to store the access token with the device for “remember me” functionality. Furthermore, we chose to implement the sign in process whereby the client takes you to the server’s web site for connection authorization. In this way, the client never sees your username and passsword, which is important if you allow third-party clients to be developed against your API (which we also want to encourage). Finally, in the event a user’s phone is stolen or otherwise compromised, an access token can be invalidated without the risk of username and password compromise.
Out of this work, came the desire to get specific modules of the Spring Framework working in an Android environment. Specifically, we aimed to use RestTemplate for the REST API calls, and Spring Security for the OAuth client.
I’m pleased announce that the first milestone of Spring Android ships an “Android-ready” RestTemplate. We’re using it in Greenhouse, and we encourage you to use it as the REST client in your own Android applications. Check out the example usage below:
RestTemplate restTemplate = new RestTemplate(new CommonsClientHttpRequestFactory());
Event event = restTemplate.getForObject(“https://myapp.com/event/{name}”, Event.class, “springone2gx”);
In future milestones, you can expect more of the Spring Framework to be supported in an Android environment, such as the Spring Security OAuth client.
Getting Started
The best way to get started is to see it live by walking through the Greenhouse app in your own local development environment. As a reference, Greenhouse uses the Spring Mobile and Spring Android projects, as well as Spring MVC, Security, Social, and Integration. The project page provides a guide that shows you how to get the web app, iPhone client, and Android client all running in your local environment in minutes.
If you have questions about features, roadmap, or just want to have a discussion with the development team, please do visit our community forums. We value your feedback.
Summary
I’m very excited about all the new initiatives we’ve got going, and especially what we’re doing in the social and mobile space. The first milestones of these projects are just the beginning. I encourage you to get involved in the projects that are useful to you and help us make them the best they can possibly be.
comments powered by Disqus
在SpringOne2gx上,我们宣布了社交媒体和移动应用程序开发领域令人兴奋的新举措。几周前,CraigWalls发布了SpringSocial。今天,Roy Clarkson发布了Spring Mobile和Spring Android。在这篇文章中,我想重点介绍这些项目,并分享Spring如何简化移动应用程序开发。
移动应用开发的选择
如果你今年参加了SpringOne2gx,你会看到greenous,一个我们为社区开发的应用程序,同时也是Spring技术的参考和驱动程序。克雷格向你展示了温室的一些社交元素,比如将你的账户与Twitter和Facebook连接起来的能力。还有一些移动设备。具体来说,greeny兼作移动web应用程序,以及iPhone和Android客户端的运动原生greeny。
像今天的许多组织一样,我们必须回答一个基本的问题:“要瞄准哪些移动平台?”?“最终,我们选择为iPhone和Android用户提供本地体验,同时还开发了一款跨平台的移动web应用程序。我们决定本土化是因为这款应用是面向消费者的,而且很多潜在的消费者(应用开发者)拥有iPhone和Android设备。同时,移动web应用旨在提供跨平台工作的良好基线体验,这在WebKit和HTML 5兴起的今天是可能的。
在我们的开发工作中,Spring框架的贡献不断增长:首先,Spring移动项目为开发移动web应用程序提供了Spring MVC的扩展;其次,Spring Android项目支持与基于Spring的后端通信的本地Android客户端的开发。我会依次带你完成这些项目。
弹簧移动式
我们解决的第一个问题是设计一个让移动用户使用起来很愉快的web应用程序。虽然智能手机可能有一个功能强大的网络浏览器,但它仍然有一个小屏幕,这需要考虑。解决这一问题的方法基本上有两种:
检测发起web请求的设备,并为移动设备提供单独的站点。
为单个站点提供服务,但通过使用CSS 3媒体查询和JavaScript逐步增强桌面用户的服务。
现在,您可以在野外找到这两种技术的示例;例如,会议站点Lanyrd通过客户端检测进行增强,而SpeakerRate使用服务器端检测,将移动访问者重定向到单独的站点(请通过安装Firefox用户代理切换器并将用户代理设置为iPhone亲自查看)。
在温室里,我们从服务器端检测开始。具体来说,如果设备是移动设备,我们的目标是应用不同的页面布局。由此产生了一个通用的“设备解析器抽象”,这是SpringMobile1.0.0.M1的定义特性。此功能的一些亮点包括:
一种HandlerInterceptor,它使用设备解算器来检测发起当前HttpServletRequest的设备。