⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 microhttpd.h

📁 一个 http 服务器的框架实现
💻 H
📖 第 1 页 / 共 2 页
字号:
 * Handle for the daemon (listening on a socket for HTTP traffic). */struct MHD_Daemon;/** * Handle for a connection / HTTP request.  With HTTP/1.1, multiple * requests can be run over the same connection.  However, MHD will * only show one request per TCP connection to the client at any given * time. */struct MHD_Connection;/** * Handle for a response. */struct MHD_Response;/** * Allow or deny a client to connect. * * * @param addr address information from the client * @param addrlen length of the address information * @return MHD_YES if connection is allowed, MHD_NO if not */typedef int  (*MHD_AcceptPolicyCallback) (void *cls,                               const struct sockaddr * addr,                               socklen_t addrlen);/** * A client has requested the given url using the given method ("GET", * "PUT", "DELETE", "POST", etc).  The callback must call MHS * callbacks to provide content to give back to the client and return * an HTTP status code (i.e. 200 for OK, 404, etc.). * * @param url the requested url * @param method the HTTP method used ("GET", "PUT", etc.) * @param version the HTTP version string (i.e. "HTTP/1.1") * @param upload_data the data being uploaded (excluding HEADERS, *        for a POST that fits into memory and that is encoded *        with a supported encoding, the POST data will NOT be *        given in upload_data and is instead available as  *        part of MHD_get_connection_values; very large POST *        data *will* be made available incrementally in *        upload_data) * @param upload_data_size set initially to the size of the *        upload_data provided; the method must update this *        value to the number of bytes NOT processed; * @return MHS_YES if the connection was handled successfully, *         MHS_NO if the socket must be closed due to a serios *         error while handling the request */typedef int  (*MHD_AccessHandlerCallback) (void *cls,                                struct MHD_Connection * connection,                                const char *url,                                const char *method,                                const char *version,                                const char *upload_data,                                unsigned int *upload_data_size);/** * Iterator over key-value pairs.  This iterator * can be used to iterate over all of the cookies, * headers, or POST-data fields of a request, and * also to iterate over the headers that have been * added to a response. * * @return MHD_YES to continue iterating, *         MHD_NO to abort the iteration */typedef int  (*MHD_KeyValueIterator) (void *cls,                           enum MHD_ValueKind kind,                           const char *key, const char *value);/** * Callback used by libmicrohttpd in order to obtain content.  The * callback is to copy at most "max" bytes of content into "buf".  The * total number of bytes that has been placed into "buf" should be * returned.<p> * * Note that returning zero will cause libmicrohttpd to try again, * either "immediately" if in multi-threaded mode (in which case the * callback may want to do blocking operations) or in the next round * if MHD_run is used.  Returning 0 for a daemon that runs in internal * select mode is an error (since it would result in busy waiting) and * will cause the program to be aborted (abort()). * * @param cls extra argument to the callback * @param pos position in the datastream to access; *        note that if an MHD_Response object is re-used, *        it is possible for the same content reader to *        be queried multiple times for the same data; *        however, if an MHD_Response is not re-used, *        libmicrohttpd guarantees that "pos" will be *        the sum of all non-negative return values *        obtained from the content reader so far. * @return -1 on error (libmicrohttpd will no longer *  try to read content and instead close the connection *  with the client). */typedef int  (*MHD_ContentReaderCallback) (void *cls, size_t pos, char *buf, int max);/** * This method is called by libmicrohttpd if we * are done with a content reader.  It should * be used to free resources associated with the * content reader. */typedef void (*MHD_ContentReaderFreeCallback) (void *cls);/** * Start a webserver on the given port. * @param flags combination of MHD_FLAG values * @param port port to bind to * @param apc callback to call to check which clients *        will be allowed to connect; you can pass NULL *        in which case connections from any IP will be *        accepted * @param apc_cls extra argument to apc * @param dh default handler for all URIs * @param dh_cls extra argument to dh * @param ... list of options (type-value pairs, *        terminated with MHD_OPTION_END). * @return NULL on error, handle to daemon on success */struct MHD_Daemon *MHD_start_daemon (unsigned int flags,                                     unsigned short port,                                     MHD_AcceptPolicyCallback apc,                                     void *apc_cls,                                     MHD_AccessHandlerCallback dh,                                     void *dh_cls, ...);/** * Shutdown an http daemon. */void MHD_stop_daemon (struct MHD_Daemon *daemon);/** * Obtain the select sets for this daemon. * * @return MHD_YES on success, MHD_NO if this *         daemon was not started with the right *         options for this call. */intMHD_get_fdset (struct MHD_Daemon *daemon,               fd_set * read_fd_set,               fd_set * write_fd_set, fd_set * except_fd_set, int *max_fd);/** * Run webserver operations (without blocking unless * in client callbacks).  This method should be called * by clients in combination with MHD_get_fdset * if the client-controlled select method is used. * * @return MHD_YES on success, MHD_NO if this *         daemon was not started with the right *         options for this call. */int MHD_run (struct MHD_Daemon *daemon);/** * Register an access handler for all URIs beginning with uri_prefix. * * @param uri_prefix * @return MRI_NO if a handler for this exact prefix *         already exists */intMHD_register_handler (struct MHD_Daemon *daemon,                      const char *uri_prefix,                      MHD_AccessHandlerCallback dh, void *dh_cls);/** * Unregister an access handler for the URIs beginning with * uri_prefix. * * @param uri_prefix * @return MHD_NO if a handler for this exact prefix *         is not known for this daemon */intMHD_unregister_handler (struct MHD_Daemon *daemon,                        const char *uri_prefix,                        MHD_AccessHandlerCallback dh, void *dh_cls);/** * Get all of the headers from the request. * * @param iterator callback to call on each header; *        maybe NULL (then just count headers) * @param iterator_cls extra argument to iterator * @return number of entries iterated over */intMHD_get_connection_values (struct MHD_Connection *connection,                           enum MHD_ValueKind kind,                           MHD_KeyValueIterator iterator, void *iterator_cls);/** * Get a particular header value.  If multiple * values match the kind, return any one of them. * * @param key the header to look for * @return NULL if no such item was found */const char *MHD_lookup_connection_value (struct MHD_Connection *connection,                                         enum MHD_ValueKind kind,                                         const char *key);/** * Queue a response to be transmitted to the client (as soon as * possible). * * @param connection the connection identifying the client * @param status_code HTTP status code (i.e. 200 for OK) * @param response response to transmit * @return MHD_NO on error (i.e. reply already sent), *         MHD_YES on success or if message has been queued */intMHD_queue_response (struct MHD_Connection *connection,                    unsigned int status_code, struct MHD_Response *response);/** * Create a response object.  The response object can be extended with * header information and then be used any number of times. * * @param size size of the data portion of the response, -1 for unknown * @param crc callback to use to obtain response data * @param crc_cls extra argument to crc * @param crfc callback to call to free crc_cls resources * @return NULL on error (i.e. invalid arguments, out of memory) */struct MHD_Response *MHD_create_response_from_callback (size_t size,                                                        MHD_ContentReaderCallback                                                        crc, void *crc_cls,                                                        MHD_ContentReaderFreeCallback                                                        crfc);/** * Create a response object.  The response object can be extended with * header information and then be used any number of times. * * @param size size of the data portion of the response * @param data the data itself * @param must_free libmicrohttpd should free data when done * @param must_copy libmicrohttpd must make a copy of data *        right away, the data maybe released anytime after *        this call returns * @return NULL on error (i.e. invalid arguments, out of memory) */struct MHD_Response *MHD_create_response_from_data (size_t size,                                                    void *data,                                                    int must_free,                                                    int must_copy);/** * Destroy a response object and associated resources.  Note that * libmicrohttpd may keep some of the resources around if the response * is still in the queue for some clients, so the memory may not * necessarily be freed immediatley. */void MHD_destroy_response (struct MHD_Response *response);/** * Add a header line to the response. * * @return MHD_NO on error (i.e. invalid header or content format). */intMHD_add_response_header (struct MHD_Response *response,                         const char *header, const char *content);/** * Delete a header line from the response. * * @return MHD_NO on error (no such header known) */intMHD_del_response_header (struct MHD_Response *response,                         const char *header, const char *content);/** * Get all of the headers added to a response. * * @param iterator callback to call on each header; *        maybe NULL (then just count headers) * @param iterator_cls extra argument to iterator * @return number of entries iterated over */intMHD_get_response_headers (struct MHD_Response *response,                          MHD_KeyValueIterator iterator, void *iterator_cls);/** * Get a particular header from the response. * * @param key which header to get * @return NULL if header does not exist */const char *MHD_get_response_header (struct MHD_Response *response,                                     const char *key);#if 0                           /* keep Emacsens' auto-indent happy */{#endif#ifdef __cplusplus}#endif#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -