# create-hmac [data:image/s3,"s3://crabby-images/44f8f/44f8fa02785c6defc1d5dcfd32f63bdf7ca576b1" alt="NPM Package"](https://www.npmjs.org/package/create-hmac) [data:image/s3,"s3://crabby-images/8c2de/8c2de428ddbd1b76a3e35c375c631d3c576fbdbd" alt="Build Status"](https://travis-ci.org/crypto-browserify/createHmac) [data:image/s3,"s3://crabby-images/2bcd7/2bcd718c8bc56b0c69aac9b9b6bf91e33941a8fd" alt="Dependency status"](https://david-dm.org/crypto-browserify/createHmac#info=dependencies) [data:image/s3,"s3://crabby-images/dba59/dba59f08817aea3ac6cbe0f21587fc57f4309bbb" alt="js-standard-style"](https://github.com/feross/standard) Node style HMACs for use in the browser, with native HMAC functions in node. API is the same as HMACs in node: ```js var createHmac = require('create-hmac') var hmac = createHmac('sha224', Buffer.from('secret key')) hmac.update('synchronous write') //optional encoding parameter hmac.digest() // synchronously get result with optional encoding parameter hmac.write('write to it as a stream') hmac.end() //remember it's a stream hmac.read() //only if you ended it as a stream though ```