SQLの窓

2009年12月24日


Flex3 : ランタイムエラー #2122 : セキュリティサンドボックス侵害 : checkPolicyFile フラグが設定されませんでした

Flex から URLLoder でデータをロードする場合は、crossdomain.xml
の存在だけで良かったのですが、イメージ (JPG、GIF、または PNG)
を呼び出し元 SWF ファイル自体のドメイン外からロードし、そのイメージ
のコンテンツに BitmapData.draw() を使用してアクセスする予定の場合に、
checkPolicyFile を true にする必要があるのですが、Image コントロールは、
デフォルトではこの設定はなされません。

loaderContext プロパティに LoaderContext のインスタンを設定して
checkPolicyFileを正しく設定する必要がありますが、trustContenttrue
にすると、必要な設定は自動的に行われてコンテンツは正しいセキュリティ
ドメインにロードされます。


しかし、この設定を行うと Image コントロールに crossdomain.xml の
正しい設定の無いドメインの画像は表示されなくなります


ランタイムエラー - ActionScript 3.0 言語およびコンポーネントリファレンス



タグ:トラブル
posted by lightbox at 2009-12-24 22:19 | 記録 | このブログの読者になる | 更新情報をチェックする

DB2 : Express-C 9.7

DB2 を触った事が無いので問題あるかもしれませんが、他の DB の知識と勘で動作確認を行いました。

DB2 Express-C (無償版DB2)

サインアップ無しでも目的等のアンケートのような入力を3種類くらいコンボボックスで選択するだけでダウンロードできます。

db2exc_970_WIN_x86.zip(399 MB)

解凍して setup.exe を実行します。

Db2admin

セットアップが終了すると、使用している自分のユーザに DB2ADMNS グループをコンピュータの管理で追加します。その後、プログラムメニューの「ファースト・ステップ」で新規データベースの作成を実行してテスト用のDBを作成するのですが、ディレクトリの中へDBファイルを入れようとすると、エラーとなるので C:\ としました(C:\DB2 が作成される)。

ODBC ドライバは、インストールで登録されているので必要ならば以上の処理後登録すると接続可能ですが、当面のDBの調査を行うには、以下のツールを実行します。

コントロールセンター
コマンド・エディター


コントロールセンターでスキーマの情報を見る事ができるので、システム表やビューのスキーマ名を確認できます。このスキーマ名で修飾する事によって、ログインユーザーからスキーマ名.テーブル名 でコマンド・エディターを使って参照できます。

サービスは、DB2 が頭に付いたサービス名か6つ登録されていますが、全て手動にしておいて、DB の起動は、コマンド・エディターからstart database manager を実行します。( 停止は、stop database manager )
開始後、対象 DB を追加して処理しますが、停止するには全てのDB2を使用するアプリケーションを終了する必要があります。コマンド・エディターでは、選択されているコンボボックスを空白にしてから、stop database manager を実行します


ドキュメントは、IBM のサイトの「サポート・ダウンロード」から、「SQL リファレンス」と検索すると PDF がダウンロードできるリンクがトップに表示されます( 1巻と2巻と二つ必要です )

CREATE TABLE では、主キー列には not NULL を明示する必要があります


Db2admin2



posted by lightbox at 2009-12-24 17:27 | 記録 | このブログの読者になる | 更新情報をチェックする

2009年12月21日


JavaScript : 正規表現で、PE-100,120 の分解  

PE-100,120 は、座標データです。
Pは通過点で、Eは最終点である事を示します。
-100 と 120 が座標で、これを分解する為に以下のような正規表現を使います。

([^\d]+?)([\-]?\d+),([\-]?\d+)

1) [^\d]+?

1〜n個の数字以外の最短の文字列です。
次のパターンに - が来る場合があり、- も数字以外なので、? が無いと
- もこちら側に来てしまいます。この ? は、正規表現で最も重要な記号です。
\d は数字を表すのですが、JavaScript では d になってしまうので注意です。
JavaScript では、\d は \\d で表す必要があります。
[] は、文字集合を表しており、省略できる場面もありますが、
出来る限り指定したほうが良いでしょう。^ は否定なので文字集合
全てを否定できます。
+ は直前のパターンの文字が1文字以上連続する事を意味します。

() は、後で部分一致として文字列を取り出す為に用います。パターン
中で複数使って、JavaScript では、後で RegExp.$1、RegExp.$2、RegExp.$3、
というように取り出すのが最も直感的で簡単です


2) [\-]?\d+

[\-]は、-文字を示しますが、後の ? は、直前の文字が0文字か1文字で
一致します。良く使われるのが https? で、http でも https でも一致します。
[] の中での - は範囲指定なので、- を示す為に \- となります

3) ,

,( カンマ ) と一致します。


記号(メタキャラクタ)一覧







タグ:正規表現
posted by lightbox at 2009-12-21 03:28 | JavaScript 正規表現 | このブログの読者になる | 更新情報をチェックする

2009年12月17日


JavaScript : 一見バグのように見える正規表現オブジェクトの正しい動作

一つ目の正規表現が一致しません。
"\d" は、結局 "d" なので、正規表現のメタ文字にはなりません。
つまり、一つ目は以下のように指定する必要があります
pat = new RegExp("([^\\d]+?)([\-]?\\d+)\,([\-]?\\d+)");
( 外部から入力される時は \d でいい事になります )
str = "PE-100,120";

pat = new RegExp("([^\d]+?)([\-]?\d+)\,([\-]?\d+)");
alert(str.match( pat ));
alert( RegExp.$1 + "|" + RegExp.$2 + "|" + RegExp.$3 );

pat = new RegExp("([^0-9]+?)([\-]?[0-9]+)\,([\-]?[0-9]+)");
alert(str.match( pat ));
alert( RegExp.$1 + "|" + RegExp.$2 + "|" + RegExp.$3 );

alert(str.match( /([^\d]+?)([\-]?\d+)\,([\-]?\d+)/ ));
alert( RegExp.$1 + "|" + RegExp.$2 + "|" + RegExp.$3 );



タグ:javascript
posted by lightbox at 2009-12-17 01:22 | JavaScript 正規表現 | このブログの読者になる | 更新情報をチェックする

2009年12月16日


GIMP : フォント作成とキャラクタデザインとScript-fuのロゴ

2009/12/16 更新
ttfedit の使い方のノウハウをまとめました。
リンクを追加しています


フォントを作成して GIMP のScript-fu でステンドグラスなキャラクタ画像を作成する


Sgb_lightbox Sgb_lightbox_a Sgb_lightbox_a2
GIMP2( 高機能グラフィックソフト ) の Script-fu を利用すると、通常のフォントを
使っていろいろなロゴを一瞬で作成できますが、そもそも、フォントを自作すると、
このような事が可能になります


関連する記事
ttfedit の使い方の、とても重要な部分


posted by lightbox at 2009-12-16 21:21 | GIMP | このブログの読者になる | 更新情報をチェックする

2009年12月15日


PHP : php-5.3.1 の日付関数の注意点

PHP のマニュアル( date 関数 )には以下のように記述されています。
すべての日付/時刻関数は、有効なタイムゾーンが設定されていない場合にE_NOTICE を発生させます。また、システム設定のタイムゾーンあるいは環境変数 TZ を使用した場合には E_STRICT あるいは E_WARNING を発生させます。
で、結論として 5.3.1 で 以下のようなメッセージが出力されます
PHP Warning:  date(): It is not safe to rely on the system's timezone settings.You are *required* to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected ' 
Asia/Tokyo' for '9.0/no DST' instead in Command line code on line 1
マニュアルの記述には、バージョンによる変更履歴が書かれていますが、少なくとも、Windows 版では事実と一致しないようで、5.2.11 だとワーニングは出ません。どちらも php.ini 無しのデフォルトでテストしました。 結局、5.3.1 の場合は、PHP.ini に以下を設定します。 ( timezone の確認は、コマンドプロンプトから php --ri date でもできます )
[Date]
date.timezone = Asia/Tokyo
関連する記事 PHP のバージョンを 5.2 から 5.4 へ変更したところ、個別に date_default_timezone_set を実行するように言われました。
posted by lightbox at 2009-12-15 15:12 | PHP | このブログの読者になる | 更新情報をチェックする
Seesaa の各ページの表示について
Seesaa の 記事がたまに全く表示されない場合があります。その場合は、設定> 詳細設定> ブログ設定 で 最新の情報に更新の『実行ボタン』で記事やアーカイブが最新にビルドされます。

Seesaa のページで、アーカイブとタグページは要注意です。タグページはコンテンツが全く無い状態になりますし、アーカイブページも歯抜けページはコンテンツが存在しないのにページが表示されてしまいます。

また、カテゴリページもそういう意味では完全ではありません。『カテゴリID-番号』というフォーマットで表示されるページですが、実際存在するより大きな番号でも表示されてしまいます。

※ インデックスページのみ、実際の記事数を超えたページを指定しても最後のページが表示されるようです

対処としては、このようなヘルプ的な情報を固定でページの最後に表示するようにするといいでしょう。具体的には、メインの記事コンテンツの下に『自由形式』を追加し、アーカイブとカテゴリページでのみ表示するように設定し、コンテンツを用意するといいと思います。


※ エキスパートモードで表示しています

アーカイブとカテゴリページはこのように簡単に設定できますが、タグページは HTML 設定を直接変更して、以下の『タグページでのみ表示される内容』の記述方法で設定する必要があります

<% if:page_name eq 'archive' -%>
アーカイブページでのみ表示される内容
<% /if %>

<% if:page_name eq 'category' -%>
カテゴリページでのみ表示される内容
<% /if %>

<% if:page_name eq 'tag' -%>
タグページでのみ表示される内容
<% /if %>
この記述は、以下の場所で使用します
container 終わり



フリーフォントで簡単ロゴ作成
フリーフォントでボタン素材作成
フリーフォントで吹き出し画像作成
フリーフォントではんこ画像作成
ほぼ自由に利用できるフリーフォント
フリーフォントの書体見本とサンプル
画像を大きく見る為のウインドウを開くボタンの作成

CSS ドロップシャドウの参考デモ
イラストAC
ぱくたそ
写真素材 足成
フリーフォント一覧
utf8 文字ツール
右サイド 終わり
base 終わり