added qse_mbstouri()/qse_wcstouri()/qse_strtouri().
added qse_enbase64()/qse_debase64(). enhanced basic authorization to httpd-std
This commit is contained in:
		@ -39,6 +39,7 @@ bin_PROGRAMS = \
 | 
			
		||||
	str01 \
 | 
			
		||||
	time \
 | 
			
		||||
	tre01 \
 | 
			
		||||
	uri01 \
 | 
			
		||||
	xma 
 | 
			
		||||
	
 | 
			
		||||
LDFLAGS = -L../../lib/cmn 
 | 
			
		||||
 | 
			
		||||
@ -42,7 +42,7 @@ bin_PROGRAMS = chr01$(EXEEXT) env$(EXEEXT) dll$(EXEEXT) fio01$(EXEEXT) \
 | 
			
		||||
	pio$(EXEEXT) pma$(EXEEXT) rex01$(EXEEXT) rbt$(EXEEXT) \
 | 
			
		||||
	sio01$(EXEEXT) sio02$(EXEEXT) sio03$(EXEEXT) sll$(EXEEXT) \
 | 
			
		||||
	slmb01$(EXEEXT) str01$(EXEEXT) time$(EXEEXT) tre01$(EXEEXT) \
 | 
			
		||||
	xma$(EXEEXT)
 | 
			
		||||
	uri01$(EXEEXT) xma$(EXEEXT)
 | 
			
		||||
@WCHAR_TRUE@@WIN32_TRUE@am__append_1 = $(UNICOWS_LIBS)
 | 
			
		||||
subdir = samples/cmn
 | 
			
		||||
DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in
 | 
			
		||||
@ -190,6 +190,10 @@ am_tre01_OBJECTS = tre01.$(OBJEXT)
 | 
			
		||||
tre01_OBJECTS = $(am_tre01_OBJECTS)
 | 
			
		||||
tre01_LDADD = $(LDADD)
 | 
			
		||||
tre01_DEPENDENCIES = $(am__DEPENDENCIES_2)
 | 
			
		||||
uri01_SOURCES = uri01.c
 | 
			
		||||
uri01_OBJECTS = uri01.$(OBJEXT)
 | 
			
		||||
uri01_LDADD = $(LDADD)
 | 
			
		||||
uri01_DEPENDENCIES = $(am__DEPENDENCIES_2)
 | 
			
		||||
am_xma_OBJECTS = xma.$(OBJEXT)
 | 
			
		||||
xma_OBJECTS = $(am_xma_OBJECTS)
 | 
			
		||||
xma_LDADD = $(LDADD)
 | 
			
		||||
@ -217,7 +221,7 @@ SOURCES = $(chr01_SOURCES) $(dll_SOURCES) $(env_SOURCES) \
 | 
			
		||||
	$(rbt_SOURCES) $(rex01_SOURCES) $(sio01_SOURCES) \
 | 
			
		||||
	$(sio02_SOURCES) $(sio03_SOURCES) $(sll_SOURCES) \
 | 
			
		||||
	$(slmb01_SOURCES) $(str01_SOURCES) $(time_SOURCES) \
 | 
			
		||||
	$(tre01_SOURCES) $(xma_SOURCES)
 | 
			
		||||
	$(tre01_SOURCES) uri01.c $(xma_SOURCES)
 | 
			
		||||
DIST_SOURCES = $(chr01_SOURCES) $(dll_SOURCES) $(env_SOURCES) \
 | 
			
		||||
	$(fio01_SOURCES) $(fio02_SOURCES) $(fma_SOURCES) \
 | 
			
		||||
	$(fmt01_SOURCES) $(fmt02_SOURCES) $(fs01_SOURCES) \
 | 
			
		||||
@ -228,7 +232,7 @@ DIST_SOURCES = $(chr01_SOURCES) $(dll_SOURCES) $(env_SOURCES) \
 | 
			
		||||
	$(rbt_SOURCES) $(rex01_SOURCES) $(sio01_SOURCES) \
 | 
			
		||||
	$(sio02_SOURCES) $(sio03_SOURCES) $(sll_SOURCES) \
 | 
			
		||||
	$(slmb01_SOURCES) $(str01_SOURCES) $(time_SOURCES) \
 | 
			
		||||
	$(tre01_SOURCES) $(xma_SOURCES)
 | 
			
		||||
	$(tre01_SOURCES) uri01.c $(xma_SOURCES)
 | 
			
		||||
ETAGS = etags
 | 
			
		||||
CTAGS = ctags
 | 
			
		||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
 | 
			
		||||
@ -598,6 +602,9 @@ time$(EXEEXT): $(time_OBJECTS) $(time_DEPENDENCIES) $(EXTRA_time_DEPENDENCIES)
 | 
			
		||||
tre01$(EXEEXT): $(tre01_OBJECTS) $(tre01_DEPENDENCIES) $(EXTRA_tre01_DEPENDENCIES) 
 | 
			
		||||
	@rm -f tre01$(EXEEXT)
 | 
			
		||||
	$(LINK) $(tre01_OBJECTS) $(tre01_LDADD) $(LIBS)
 | 
			
		||||
uri01$(EXEEXT): $(uri01_OBJECTS) $(uri01_DEPENDENCIES) $(EXTRA_uri01_DEPENDENCIES) 
 | 
			
		||||
	@rm -f uri01$(EXEEXT)
 | 
			
		||||
	$(LINK) $(uri01_OBJECTS) $(uri01_LDADD) $(LIBS)
 | 
			
		||||
xma$(EXEEXT): $(xma_OBJECTS) $(xma_DEPENDENCIES) $(EXTRA_xma_DEPENDENCIES) 
 | 
			
		||||
	@rm -f xma$(EXEEXT)
 | 
			
		||||
	$(LINK) $(xma_OBJECTS) $(xma_LDADD) $(LIBS)
 | 
			
		||||
@ -640,6 +647,7 @@ distclean-compile:
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/str01.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/time.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tre01.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/uri01.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xma.Po@am__quote@
 | 
			
		||||
 | 
			
		||||
.c.o:
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										139
									
								
								qse/samples/cmn/uri01.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										139
									
								
								qse/samples/cmn/uri01.c
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,139 @@
 | 
			
		||||
#include <qse/cmn/uri.h>
 | 
			
		||||
#include <qse/cmn/main.h>
 | 
			
		||||
#include <qse/cmn/mbwc.h>
 | 
			
		||||
#include <qse/cmn/stdio.h>
 | 
			
		||||
 | 
			
		||||
#include <locale.h>
 | 
			
		||||
#if defined(_WIN32)
 | 
			
		||||
#	include <windows.h>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
static void xxx (const qse_wchar_t* ptr, qse_size_t len)
 | 
			
		||||
{
 | 
			
		||||
	if (ptr)
 | 
			
		||||
	{
 | 
			
		||||
		qse_size_t i;
 | 
			
		||||
		qse_printf (QSE_T(" ["));
 | 
			
		||||
		for (i = 0; i < len; i++)
 | 
			
		||||
			qse_printf (QSE_T("%hc"), ptr[i]);
 | 
			
		||||
		qse_printf (QSE_T("] "));
 | 
			
		||||
	}
 | 
			
		||||
	else
 | 
			
		||||
	{
 | 
			
		||||
		qse_printf (QSE_T(" (null) "));
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int test_main (int argc, qse_char_t* argv[], qse_char_t* envp[])
 | 
			
		||||
{
 | 
			
		||||
	static const qse_wchar_t* wcs[] =
 | 
			
		||||
	{
 | 
			
		||||
		QSE_WT("http://www.google.com"),
 | 
			
		||||
		QSE_WT("http://www.google.com:80"),
 | 
			
		||||
		QSE_WT("http://abc@www.google.com:80"),
 | 
			
		||||
		QSE_WT("http://abc:def@www.google.com:80"),
 | 
			
		||||
		QSE_WT("http://abc:def@www.google.com:80/"),
 | 
			
		||||
		QSE_WT("http://abc:def@www.google.com:80/?#"),
 | 
			
		||||
		QSE_WT("http://abc:def@www.google.com:80/abcdef/ghi?kkk=23#fragment"),
 | 
			
		||||
		QSE_WT("http://abc:def@www.google.com:80/abcdef/ghi#fragment#fragment"),
 | 
			
		||||
		QSE_WT("http://abc:def@www@.google.com:80/abcdef/ghi#fragment#fragment"),
 | 
			
		||||
		QSE_WT("http://@@@@@abc:def@www@.google.com:80/abcdef/ghi#fragment#fragment")
 | 
			
		||||
	};
 | 
			
		||||
 | 
			
		||||
	qse_size_t i;
 | 
			
		||||
	qse_uri_t uri;
 | 
			
		||||
 | 
			
		||||
	for (i = 0; i < QSE_COUNTOF(wcs); i++)
 | 
			
		||||
	{
 | 
			
		||||
		qse_printf (QSE_T("[%ls] => "), wcs[i]);
 | 
			
		||||
		if (qse_wcstouri (wcs[i], &uri, 0) <= -1)
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("[ERROR]"));
 | 
			
		||||
		}
 | 
			
		||||
		else
 | 
			
		||||
		{
 | 
			
		||||
			xxx (uri.scheme.ptr, uri.scheme.len);
 | 
			
		||||
			xxx (uri.auth.user.ptr, uri.auth.user.len);
 | 
			
		||||
			xxx (uri.auth.pass.ptr, uri.auth.pass.len);
 | 
			
		||||
			xxx (uri.host.ptr, uri.host.len);
 | 
			
		||||
			xxx (uri.port.ptr, uri.port.len);
 | 
			
		||||
			xxx (uri.path.ptr, uri.path.len);
 | 
			
		||||
			xxx (uri.query.ptr, uri.query.len);
 | 
			
		||||
			xxx (uri.frag.ptr, uri.frag.len);
 | 
			
		||||
		}
 | 
			
		||||
		qse_printf (QSE_T("\n"));
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("================================================\n"));
 | 
			
		||||
 | 
			
		||||
	for (i = 0; i < QSE_COUNTOF(wcs); i++)
 | 
			
		||||
	{
 | 
			
		||||
		qse_printf (QSE_T("[%ls] => "), wcs[i]);
 | 
			
		||||
		if (qse_wcstouri (wcs[i], &uri, QSE_WCSTOURI_NOQUERY | QSE_WCSTOURI_NOAUTH) <= -1)
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("[ERROR]"));
 | 
			
		||||
		}
 | 
			
		||||
		else
 | 
			
		||||
		{
 | 
			
		||||
			xxx (uri.scheme.ptr, uri.scheme.len);
 | 
			
		||||
			xxx (uri.auth.user.ptr, uri.auth.user.len);
 | 
			
		||||
			xxx (uri.auth.pass.ptr, uri.auth.pass.len);
 | 
			
		||||
			xxx (uri.host.ptr, uri.host.len);
 | 
			
		||||
			xxx (uri.port.ptr, uri.port.len);
 | 
			
		||||
			xxx (uri.path.ptr, uri.path.len);
 | 
			
		||||
			xxx (uri.query.ptr, uri.query.len);
 | 
			
		||||
			xxx (uri.frag.ptr, uri.frag.len);
 | 
			
		||||
		}
 | 
			
		||||
		qse_printf (QSE_T("\n"));
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("================================================\n"));
 | 
			
		||||
 | 
			
		||||
	for (i = 0; i < QSE_COUNTOF(wcs); i++)
 | 
			
		||||
	{
 | 
			
		||||
		qse_printf (QSE_T("[%ls] => "), wcs[i]);
 | 
			
		||||
		if (qse_wcstouri (wcs[i], &uri, QSE_WCSTOURI_NOQUERY | QSE_WCSTOURI_NOAUTH | QSE_WCSTOURI_NOFRAG) <= -1)
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("[ERROR]"));
 | 
			
		||||
		}
 | 
			
		||||
		else
 | 
			
		||||
		{
 | 
			
		||||
			xxx (uri.scheme.ptr, uri.scheme.len);
 | 
			
		||||
			xxx (uri.auth.user.ptr, uri.auth.user.len);
 | 
			
		||||
			xxx (uri.auth.pass.ptr, uri.auth.pass.len);
 | 
			
		||||
			xxx (uri.host.ptr, uri.host.len);
 | 
			
		||||
			xxx (uri.port.ptr, uri.port.len);
 | 
			
		||||
			xxx (uri.path.ptr, uri.path.len);
 | 
			
		||||
			xxx (uri.query.ptr, uri.query.len);
 | 
			
		||||
			xxx (uri.frag.ptr, uri.frag.len);
 | 
			
		||||
		}
 | 
			
		||||
		qse_printf (QSE_T("\n"));
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("================================================\n"));
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int qse_main (int argc, qse_achar_t* argv[], qse_achar_t* envp[])
 | 
			
		||||
{
 | 
			
		||||
#if defined(_WIN32)
 | 
			
		||||
     char locale[100];
 | 
			
		||||
	UINT codepage = GetConsoleOutputCP();	
 | 
			
		||||
	if (codepage == CP_UTF8)
 | 
			
		||||
	{
 | 
			
		||||
		/*SetConsoleOUtputCP (CP_UTF8);*/
 | 
			
		||||
		qse_setdflcmgr (qse_utf8cmgr);
 | 
			
		||||
	}
 | 
			
		||||
	else
 | 
			
		||||
	{
 | 
			
		||||
     	sprintf (locale, ".%u", (unsigned int)codepage);
 | 
			
		||||
     	setlocale (LC_ALL, locale);
 | 
			
		||||
		qse_setdflcmgrbyid (QSE_CMGR_SLMB);
 | 
			
		||||
	}
 | 
			
		||||
#else
 | 
			
		||||
     setlocale (LC_ALL, "");
 | 
			
		||||
	qse_setdflcmgrbyid (QSE_CMGR_SLMB);
 | 
			
		||||
#endif
 | 
			
		||||
     return qse_runmainwithenv (argc, argv, envp, test_main);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -55,6 +55,7 @@ static void sigint (int sig)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* --------------------------------------------------------------------- */
 | 
			
		||||
#if 0
 | 
			
		||||
static qse_httpd_server_t* attach_server (qse_httpd_t* httpd, const qse_char_t* uri)
 | 
			
		||||
{
 | 
			
		||||
	qse_httpd_server_t server, * xserver;
 | 
			
		||||
@ -93,6 +94,7 @@ static qse_httpd_server_t* attach_server (qse_httpd_t* httpd, const qse_char_t*
 | 
			
		||||
 | 
			
		||||
	return xserver;
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* --------------------------------------------------------------------- */
 | 
			
		||||
static int httpd_main (int argc, qse_char_t* argv[])
 | 
			
		||||
@ -116,7 +118,7 @@ static int httpd_main (int argc, qse_char_t* argv[])
 | 
			
		||||
 | 
			
		||||
	for (i = 1; i < argc; i++)
 | 
			
		||||
	{
 | 
			
		||||
		if (attach_server (httpd, argv[i]) == QSE_NULL)
 | 
			
		||||
		if (qse_httpd_attachserverstd (httpd, argv[i], 0) == QSE_NULL)
 | 
			
		||||
		{
 | 
			
		||||
			qse_fprintf (QSE_STDERR,
 | 
			
		||||
				QSE_T("Failed to add httpd listener - %s\n"), argv[i]);
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user