读研时的毕业论文就是DRM在移动设备上的研究及实现。当初选完这个题就后悔了,这玩意儿在中国不可能有存在的可能性,也是不可能铺开的。
Google在2.3以后也加入了DRM的支持,也许在国外,这玩意儿还真有存在的空间。
Google has pushed a change into AOSP which integrates DRM support into Stagefright recently:
http://android.git.kernel.org/?p=platform/frameworks/base.git;a=commitdiff;h=d5770917a50a828cb4337c2a392b3e4a375624b9#patch121)Extension in DataSource interface:
// for DRM virtual DecryptHandle* DrmInitialization(DrmManagerClient *client) { return NULL; } virtual void getDrmInfo(DecryptHandle **handle, DrmManagerClient **client) {};
// for DRM virtual void setDrmFlag(bool flag) {}; virtual char* getDrmTrackInfo(size_t trackID, int *len) { return NULL; }
3)DRMExtractor and the DRM format sniffer:
SniffDRM is registered to identify DRM-protected files and its original container format. As mentioned, for CONTAINER_BASED encryption, FileSource handles data decryption transparently for parsers. For the other scheme, which are encrypted with sample/NAL as the basic unit, DRMExtractor is created to wrap the original MediaExtractor, to decrypt data after reading each sample/NAL from the original extractor. In this way, DRM related stuff is separated from actual file parsers.
However, as DRM is usually an extension based on the underlying container format, so it may not be as easily decoupled from file parser when it comes to other protection schemes. For example, Microsoft's PIFF extension to ISO base media format requires IV for each sample, and details of sub-sample encryption info if applicable, etc. Besides, it also imposes duplicate logic in DRM service to recognize the original container format for non-CONTAINER_BASED encryption.转自:
http://freepine.blogspot.com/2010/11/drm-integration-in-stagefright.html