我可以从Windows上运行的ASP Classic / Javascript连接到CouchDB吗?

时间:2012-06-29 07:28:53

标签: asp-classic couchdb cloudant

Cloudant提供托管的CouchDB,免费启动级别允许每月6GB的IO。  适合开发人员学习CouchDB。

由于CouchDB允许在Javascript中指定map / reduce函数,因此通过Javascript连接到它可能是有意义的,在Classic ASP中运行。

可能?

1 个答案:

答案 0 :(得分:2)

是的,为什么不呢?

Cloudant可通过HTTP / REST访问。没什么特别的。

ASP Classic / Javascript可以使用MSXML2.ServerXMLHttp发送请求,这与XMLHttpRequest可以在客户端Javascript上使用的方式非常相似。

CouchDB的Javascript库不会假设它在浏览器中运行,也不在Node中运行,因为ASP Classic既不是那些也不是。这是一个开始:

https://gist.github.com/3016476

示例ASP代码:

    var creds = getCloudantCredentials("cloudantCreds.txt");
    var couch = new CouchDB(couchUrl);
    couch.connect(creds[0],creds[1]);
    var r = couch.listDbs();
    say("all dbs: " + JSON.stringify(r, null, 2));

    r = couch.view('dbname', 'baseViews', 'bywords',
                   { include_docs: false,
                     key: "whatever",
                     reduce:true} );
    say("view: " + JSON.stringify(r, null, 2));

这是您创建一组视图的方法:

function createViews(dbName, viewSet) {
    var r, doc,
        empty = function(doc) {
            if ( ! doc.observation || doc.observation === '') {
                emit(null, doc);
            }
        },
        bywordsMap = function(doc) {
            var tokens, re1,
                uniq = function(a) {
                    var o = {}, i = 0, L = a.length, r = [];
                    for (; i < L; i++) {
                        if (a[i] !== '' && a[i] !== ' ') {
                            o[a[i]] = a[i];
                        }
                    }
                    for (i in o) { r.push(o[i]); }
                    return r;
                };

            if ( doc.observation && doc.observation !== '') {
                tokens = uniq(doc.observation.split(/( +)|\./));
                if (tokens && tokens.length > 0) {
                    tokens.map(function(token) {
                        emit(token, 1);
                    });
                }
            }
        };

    viewSet = viewSet || 'baseViews';
    try {
        r = couch.deleteView(dbName, viewSet);
        doc = { views: { empty:   { map:stringRep(empty) },
                         bywords: { map:stringRep(bywordsMap)}}};
        r = couch.createView(dbName, viewSet, doc);
    }
    catch (exc1) {
        say ('createViews() failed: ' + JSON.stringify(exc1));
    }
}


function stringRep(fn) {
    return fn.toString()
        .replace(/[\s\t]*\/\/.*$/gm, '') // comments
        .replace(/\n */gm, ' ')
        .replace(/\r */gm, ' ')
        .replace(/\{ +/gm, '{')
        .replace(/ +\}/gm, '}');
}